文档库 最新最全的文档下载
当前位置:文档库 › 西安石油大学数据结构数据结构程序设计报告--设计一个一元稀疏多项式简单计算器和集合的并,交和差运算

西安石油大学数据结构数据结构程序设计报告--设计一个一元稀疏多项式简单计算器和集合的并,交和差运算

西安石油大学数据结构数据结构程序设计报告--设计一个一元稀疏多项式简单计算器和集合的并,交和差运算
西安石油大学数据结构数据结构程序设计报告--设计一个一元稀疏多项式简单计算器和集合的并,交和差运算

数据结构课程设计

题目一:设计一个一元稀疏多项式简单计算器题目二:集合的并,交和差运算

班级:计1101

姓名:张文江

学期:2012-2013学年第二学期

上机实验报告(一)

一、题目:设计一元稀疏多项式简单计数器

二、问题描述:

(1)定义两个单链表用于存储两个多项式,存储好在输出时按指数降序输出。

(2)按指数降序排列时要注意指数的比较以及指数相同与不同时的计算方法。

(3)设计出其运算的加、减函数。

(4)再设计一个释放空间的函数用于退出系统操作。

(5)设计一个测试主函数,实现对基于顺序队列结构的一元多项式算法的测试。

(6)为了界面显示友好期间可以设计一下输出后的界面格式。

三、基本要求:

(1)输入并建立多项式,输出多项式,序列按指数降序排列;

(2)多项式a和b相加,建立多项式a+b,输出相加的多项式;

(3)多项式a和b相减,建立多项式a-b,输出相减的多项式;

(4)用带头结点的单链表存储多项式。

四、测试数据:

(1)(2x+5x8-3.1x11)+(7-5x8+11x9)

(2)(6x-3-x+4.4x2-1.2x9)-(-6x-3+5.4x2+7.8x15)

(3)(x+x2+x3)+0

(4)(x+x3)-(-x-x-3)

五、算法思想:

利用单链表来存储多项式,因此这里需要创建两个单链表分别用于存储多项式a和b,然后逐项在链表中按指数降序排列插入;利用数学中的加法方法,比较两个多项式,利用指数进行比较,进行减法计算方法时利用加法的逆运算实现,最后将输入的多项式按不同的要求提示进行函数调用实现。

六、模块划分:

头文件为:

# include

# include

//结点结构体

typedef struct PolyNode

{

float coef; //系数域

int exp; //指数域

struct PolyNode *next; //指针域

}*Poly,PolyNode;

//1、按指数降序插入多项式

void Insert(Poly p,Poly h)

//2、创建多项式(带有头结点且有m项)

Poly Create(Poly head, int m)

//3、对两个多项式进行比较判别

//4、实现多项式相加

//5、实现多项式相减(思想:兩数相减=两个正数的相反数相减)

//6、输出多项式

void Print(Poly P)

//7、销毁多项式(使用完后用于退出,释放空间)

测试主int main()

{

int m,n,flag=0;

Poly pa=0,pb=0,pc,pd;

//输出菜单

printf("************************************************************************ **\n");

printf(" 1.输入多项式2.输出多项式a和b 3.建立多项式a+b 4.建立多项式a-b 5.退出程序\n");

printf("************************************************************************ **\n");

for(;;flag=0)

{

printf("执行操作为:") ;

scanf("%d",&flag);

if(flag==1)

{

//定义各式的头指针,pa与pb在使用前付初值NULL

printf("请输入a的项数:") ;

scanf("%d",&m);

pa=CreateList(pa,m); //建立多项式a

printf("请输入b的项数:" );

scanf("%d",&n);

pb=CreateList(pb,n); //建立多项式b

}

if(flag==2)

{

printf("多项式a为:");

OutputList(pa);

printf("多项式b为:");

OutputList(pb);

continue;

}

if(flag==3)

{

pc=AddPoly(pa,pb);

printf("多项式a+b为:");

OutputList(pc);

DestroyList(pc);

continue;

}

if(flag==4)

{

pd=SubtractPoly(pa,pb);

printf("多项式a-b为:");

OutputList(pd);

DestroyList(pd);

continue;

}

if(flag==5)

break;

if(flag<1||flag>5)

printf("输入错误!!!请重新选择!!\n");

continue;

}

DestroyList(pa);

DestroyList(pb);

return 0;

}

函数:

七、源程序:

int main()

{

int m,n,flag=0;

Poly pa=0,pb=0,pc,pd;

//输出菜单

printf("************************************************************************ **\n");

printf(" 1.输入多项式2.输出多项式a和b 3.建立多项式a+b 4.建立多项式a-b 5.退出程序\n");

printf("************************************************************************ **\n");

for(;;flag=0)

{

printf("执行操作为:") ;

scanf("%d",&flag);

if(flag==1)

{

//定义各式的头指针,pa与pb在使用前付初值NULL

printf("请输入a的项数:") ;

scanf("%d",&m);

pa=CreateList(pa,m); //建立多项式a

printf("请输入b的项数:" );

scanf("%d",&n);

pb=CreateList(pb,n); //建立多项式b }

if(flag==2)

{

printf("多项式a为:");

OutputList(pa);

printf("多项式b为:");

OutputList(pb);

continue;

}

if(flag==3)

{

pc=AddPoly(pa,pb);

printf("多项式a+b为:");

OutputList(pc);

DestroyList(pc);

continue;

}

if(flag==4)

{

pd=SubtractPoly(pa,pb);

printf("多项式a-b为:");

OutputList(pd);

DestroyList(pd);

continue;

}

if(flag==5)

break;

if(flag<1||flag>5)

printf("输入错误!!!请重新选择!!\n");

continue;

}

DestroyList(pa);

DestroyList(pb);

return 0;

}

八、测试情况:(1)

(2)测试结果分析:

程序设计结果和人工模拟分析过程完全相同,说明程序正确。

(3)思想感悟:

经过这次的课程设计,我学到了好多,也越发的感觉到自己不知道的东西很多,一开始,对多项式的创建一窍不通,感觉很难,无法入手,后来,经过上网查询,与队友的讨论,逐渐有了头绪,慢慢写出了程序,第一次运行时,错误很多,改了好多次,终于成功了,让我感觉到了团队的力量!

上级实验报告(二)

一、题目:集合的并、交和差运算

二、问题描述:

(1)创建单链表用于存储集合,存储好集合在输出时按字母排好顺序输出。

(2)设计出其运算的合并、求交、求差函数。

(3)再设计一个释放空间的函数用于退出系统操作。

(4)设计一个测试主函数,实现对基于顺序队列结构的集合运算的测试。

(5)为了界面显示友好期间可以设计一下输出后的界面格式。

三、基本功能

编制一个能演示执行集合的并、交和差运算的程序。

四、基本要求

(1)集合的元素限定为小写字母字符[‘a’..’z’];

(2)演示程序以用户和计算机的对话方式执行。

五、测试数据

(1)Set1 = ”magazine”, Set2 = ”paper”,

Set1∪Set2 = ”aegimnprz”, Set1∩Set2 = ”ae”, Set1-Set2 = ”gimnz”;

(2)Set1 = ”012oper4a6tion89”, Set2 = ”error data”,

Set1∪Set2 = ”adeinoprt”, Set1∩Set2 = ”aeort”, Set1-Set2 = ”inp”。

六、算法思想:

创建一个单链表用于存储一个集合,限定集合元素字母为“a”—“z”,计算出集合的长度以用于对集合中的元素排序,排序时从第一个元素开始逐个向后比较。计算时,合并思想为:将两个集合进行比较,有相同元素时只输入一个,元素不同时均输入;求交思想:两个集合比较将相同的元素输出;求差思想:用第一个集合中的元素和第二个集合比较,如果相同就删除,最后输出剩余的元素。利用销毁和清空方法释放占据的空间,最后在主函数中将集合按不同的要求提示进行函数调用实现。

七、模块划分:

头文件:

#include

#include

#define ElemType char //宏定义一个字符型的元素类型,以下使用不用定义

//定义集合结构体

typedef struct ElemNode

{

ElemType elem; //集合元素域

struct ElemNode *next;

}*Set,ElemNode;

//1、计算一个集合的长度用于对集合排序

int Length(Set src)

//2、创建一个从a-z字母集合

void Create(Set dest)

//3、清空一个集合

void Empty(Set dest)

//4、销毁集合

void Destroy(Set dest)

//5、对一个字母集合进行从小到大的排序

void Sort(Set dest)

//6、打印集合的所有元素

void Display(Set src)

//7、判断元素是否存在于集合中

int ExistElem(Set dest, ElemType e)

//8、删除集合中的一个元素一次

void DelElem(Set dest, ElemType e)

//9、在链表尾部追加一个元素

void AddElem(Set dest, ElemType e)

//10、集合合并运算

void Add(Set dest, Set src1, Set src2)

//11、集合求交集运算

void Mul(Set dest, Set src1, Set src2)

//12、集合求差运算

void Subtract(Set dest, Set src1, Set src2)

//测试主函数

int main()

八、源程序:

#include

#include

#define ElemType char //宏定义一个字符型的元素类型,以下使用不用定义//定义集合结构体

typedef struct ElemNode

{

ElemType elem; //集合元素域

struct ElemNode *next;

}*Set,ElemNode;

//1、计算一个集合的长度用于对集合排序

int Length(Set src)

{

int i=0;

while(src->next != NULL) //集合元素不为空时i+1

{ i++;

src=src->next; //依次向后

}

return i;

}

//2、创建一个从a-z字母集合

void Create(Set dest)

{

ElemType ch; Set p = dest,n;

for(;;)

{

ch = getchar(); //输入字符

if(ch == '\n') //遇到换行(一个集合输入完成)就返回终止

break;

if(ch<97 || ch>122) //输入的字符不属于a-z 就终止运行,用于实现限定元素功能 continue;

n = (Set)malloc(sizeof(ElemNode)); //为集合n分配存储空间

p->next = n; n->elem = ch; //将字符插入集合

n->next = NULL; p = n;

}

return ;

}

//3、清空一个集合

void Empty(Set dest)

{ Set p,n;

while(dest->next != NULL)

{

p = dest; n = p->next;

for(;n->next!=NULL;)

{

p = n; n = n->next;

} free(n);

p->next = NULL;

}

}

//4、销毁集合

void Destroy(Set dest)

{

Empty(dest); free(dest);

}

//5、对一个字母集合进行从小到大的排序

void Sort(Set dest)

{

int i,j,l,flag; Set p,q,n;

l=Length(dest);

if(l<2) return;

flag=1;

for(i=l-1;i>0 && flag==1;i--)

{

flag = 0; p = dest;

q = p->next; n = q->next;

for(j=0;j

{ if(q->elem>n->elem) {

flag = 1; p->next = n; q->next = n->next; n->next = q; q = p->next; n = q->next; }

p = q; q = n;

n = n->next; }

}

}

//6、打印集合的所有元素

void Display(Set src)

{ Set p;

if(src->next == NULL)

{

printf(" φ"); return ;

}

p = src;

{

p = p->next;

putchar(p->elem);

}while(p->next != NULL);

}

//7、判断元素是否存在于集合中

int ExistElem(Set dest, ElemType e) {

Set p=dest;

if(Length(p)==0) return 0;

else{ p=p->next;

while(p->elem != e)

{

if(p->next==NULL) return 0;

p=p->next;

}

return 1;

}

}

//8、删除集合中的一个元素一次

void DelElem(Set dest, ElemType e) {

Set p=dest,q;

if(Length(p)==0) return ; q=p->next;

if(Length(p)==1)

{

p->next=NULL; free(q); }

while(q->elem!=e)

{

p=p->next; q=q->next; }

if(q->next==NULL)

{

p->next=NULL; free(q); }

Else p->next=q->next; }

//9、在链表尾部追加一个元素

void AddElem(Set dest, ElemType e) {

Set p=dest, n;

while(p->next!=NULL) p=p->next;

n=(Set)malloc(sizeof(ElemNode));

p->next=n; n->elem=e;

n->next=NULL;

}

//10、集合合并运算

void Add(Set dest, Set src1, Set src2)

{

Sort(src1); Sort(src2);

int i=0,j=0,len1 = Length(src1),len2=Length(src2); src1=src1->next; src2=src2->next;

while(i

{

if(src1->elem <= src2->elem)

{

i++;

if(!ExistElem(dest, src1->elem))

{

AddElem(dest, src1->elem); src1 = src1->next; } else

{

src1 = src1->next;

}

} else

{

j++;

if(!ExistElem(dest, src2->elem))

{

AddElem(dest, src2->elem);

src2 = src2->next;

} else

{

src2 = src2->next;

}

}

}

while(i

{

i++;

if(!ExistElem(dest, src1->elem))

{

AddElem(dest, src1->elem);

src1 = src1->next;

}

}

while(j

{

j++;

if(!ExistElem(dest, src2->elem))

{

AddElem(dest, src2->elem);

src2 = src2->next;

}

}

}

//11、集合求交集运算

void Mul(Set dest, Set src1, Set src2)

{

Sort(src1); Sort(src2);

int i=0,j=0;

int len1=Length(src1),len2=Length(src2);

src1=src1->next;src2=src2->next;

while(i

{

if(src1->elemelem) {i++;src1=src1->next;}

else if(src1->elem>src2->elem) {j++;src2=src2->next;} else {

i++;j++;

if(!ExistElem(dest, src1->elem))

{

AddElem(dest, src1->elem);

src1=src1->next; src2=src2->next;

}

}

}

}

//12、集合求差运算

void Subtract(Set dest, Set src1, Set src2) {

Sort(src1); Sort(src2);

int i = 0; int len = Length(src1);

src1 = src1->next;

while(i

{

i++;

if(!ExistElem(src2, src1->elem))

{

if(!ExistElem(dest, src1->elem))

{

AddElem(dest, src1->elem);

src1 = src1->next;

}

}else{

src1 = src1->next;

}

}

}

//测试主函数

int main()

{ int a,f;

Set dest=(Set)malloc(sizeof(ElemNode));

Set src1=(Set)malloc(sizeof(ElemNode));

Set src2=(Set)malloc(sizeof(ElemNode));

dest->next=NULL;

printf("********************************\n"); printf("* \t欢迎使用集合运算系统 *\n"); printf("* 请输入两个集合:\n");

Create(src1); Create(src2);

printf("* Set1 = "); Display(src1);

printf("\n"); printf("* Set2 = "); Display(src2); printf("\n");

printf("*********************************\n"); printf("****** 集合运算的操作菜单 ******\n"); printf("*\t1、求解集合的并 \t*\n");

printf("*\t2、求解集合的交 \t*\n");

printf("*\t3、求解集合的差 \t*\n");

printf("*\t4、退出系统 \t*\n");

printf("*********************************\n"); while(a)

{

printf("请输入您要执行操作的选项:\n");

scanf("%d",&f);

switch(f){

case 1:

printf("集合并运算:Set1∪Set2 = ");

Add(dest, src1, src2);

Display(dest); Empty(dest);

printf("\n"); break;

case 2:

printf("集合交运算:Set1∩Set2 = ");

Mul(dest, src1, src2);

Display(dest); Empty(dest);

printf("\n"); break;

case 3:

printf("集合差运算:Set1-Set2 = ");

Subtract(dest, src1, src2);

Display(dest); Empty(dest);

printf("\n"); break;

case 4:

printf("*感谢使用我的集合运算操作系统!\n");

Destroy(dest); a =0;

printf("\n"); break;

default:

printf("输入错误!请重新输入操作选项\n");

printf("*********************************\n");

break;

}

}

}

九、测试情况:

(1)测试结果分析:

程序设计结果和人工模拟分析过程完全相同,说明程序正确。(2)

(3)思想感悟:

对于此次的上机实验,我感觉收获巨大。对于编程的感悟以及思想有了深刻的了解。我希望今后这样的上级机会会更加的多。给我们等多的实验机会。!

数据结构实验多项式加法

数据结构实验报告 实验名称:多项式加减法 学号:1200310419 姓名:林强 实验日期:2015.5.05 一、实验目的 通过实现多项式的加减法,对链表有更深入的了解 二、实验具体内容 1、实验题目1: (1)题目设计一个一元稀疏多项式简单的加减法计算器 实现要求: 一元稀疏多项式简单计算器的基本功能是: (1)输入并建立多项式: 85 17 A+ x + x =; + 3 9 x 7 ) (x 79 8 x B- + = x 22 8 x ) (x (2)输出多项式 (3)多项式A和B相加,建立多项式C=A+B,并输出相加的结果多项式C (4)选作:多项式A和B相减,建立多项式C=A-B,并输出相加的结果多项式D (2)分析 1:本程序的任务是实现两个多项式的加法其中多项式的系数为浮点型, 指数为整数,输出的结果也为系数和指数。 (1)输入的形式和输入值的范围: 输入多项式的系数a和未知数X的指数b,当a和b都为零时,输入结束。输入值的范围:a为实数,b为整数。 (2)输出形式:输出多项式的系数和多项式未知数X的指数即(a,b)形式。 (3)程序所能达到的功能,实现两个多项式的加法,并输出最后的结果 2: 整个程序运行期间实行动态创建节点,一边输入数据, 一边创建节点当将全部数据输入到单链表中后再调用多项式加法这 个函数,并一边实现多项式的相加,一边释放节点,有效防止了 在程序反复运行过程中可能出现系统空间不够分配的现象 (3)实验代码 typedef int Status; #define OVERFLOW -1 #define null 0 typedef struct Lnode{

数据结构课程设计报告一元多项式的计算

数据结构课程设计报告题目:一元多项式计算 院(系):计算机与信息科学学院 专业:软件工程 班级:软件1202班 学号:02 05 40 姓名:陈潇潇刘敏易庆鹏 指导教师:彭代文 2013年12月

目录 一、课程设计介绍 ........................错误!未定义书签。 1.1课程设计目的 (3) 1.2课程设计内容 (3) 1.2课程设计要求 (3) 二、需求设计 ............................错误!未定义书签。 2.1课设题目粗略分析 (3) 2.2原理图介绍.......................... 错误!未定义书签。 2.2.1 功能模块图...................... 错误!未定义书签。 2.2.2 流程图分析 (4) 三、需求分析 .............................错误!未定义书签。 3.1存储结构 (5) 3.2算法描述 (6) 四、调试与分析 ...........................错误!未定义书签。(1)调试过程 .......................... 错误!未定义书签。(2)程序执行过程...................... 错误!未定义书签。参考文献.................................错误!未定义书签。总结.....................................错误!未定义书签。附录(关键部分程序清单)...............错误!未定义书签。

一、课程设计介绍 1.1课程设计目的 ⑴熟悉使用c语言编码程序,解决实际问题; ⑵了解数据结构与算法的设计方法,具备初步的独立分析和设计能力。 ⑶初步掌握软件开发过程的分析能力,系统设计,程序编码,测试等基本能力。 ⑷提高综合运用的能力,运用所学理论知识与独立分析能力。 1.2课程设计内容 一元多项式计算 任务:⑴能够按照指数降序排列建立并输出多项式 ⑵能够完成两个多项式的相加,并将结果输入 ⑶在上交资料中请写明:存储结构、多项式相加的基本过程的算法(可以使用程序流程图)、源程序、测试数据和结果、算法的时间复杂度、另外可以提出算法的改进方法 1.3课程设计要求 ⑴学生必须仔细阅读《数据结构》课程设计方案,认真主动完成课设的要求。有问题及时主动通过各种方式与教师联系沟通。 ⑵学生要发挥自主学习的能力,充分利用时间,安排好课设的时间计划,并在课设过程中不断检测自己的计划完成情况,及时的向教师汇报。 ⑶课程设计按照教学要求需要一周时间完成,一周中每天(按每周5天)至少要上3-4小时的机来调试C语言设计的程序,总共至少要上机调试程序30小时。 ⑷课程设计在期末考试之前交。最好一起上交。 ⑸同班同学之间最好不要相同。源代码可以打印,但是下面模块要求的内容必须手写。 二、需求设计 2.1 课设题目粗略分析 建立一元多项式并按照指数降序排列输出多项式,将一元多项式输入并存储在内存中,能够完成两个多项式的加减运算并输出结果

一元多项式加减乘除运算

中国计量学院实验报告 实验课程:算法与数据结构实验名称:一元二项式班级:学号: 姓名:实验日期: 2013-5-7 一.实验题目: ①创建2个一元多项式 ②实现2个多项式相加 ③实现2个多项式相减 ④实现2个多项式相乘 ⑤实现2个多项式相除 ⑥销毁一元多项式 实验成绩:指导教师:

二.算法说明 ①存储结构:一元多项式的表示在计算机内可以用链表来表示,为了节省存储 空间,只存储多项式中系数非零的项。链表中的每一个结点存放多项式的一个系数非零项,它包含三个域,分别存放该项的系数、指数以及指向下一个多项式项结点的指针。创建一元多项式链表,对一元多项式的运算中会出现的各种可能情况进行分析,实现一元多项式的相加、相减操作。 ②加法算法

三.测试结果 四.分析与探讨 实验数据正确,部分代码过于赘余,可以精简。 五.附录:源代码#include<> #include<> #include<> typedef struct Polynomial { float coef; int expn; struct Polynomial *next; }*Polyn,Polynomial; 出多项式a和b\n\t2.多项式相加a+b\n\t3.多项式相减a-b\n"); printf("\t4.多项式相除a*b\n\t5.多项式相除a/b\n\t6.销毁多项式\n"); printf("\t7.退出

\n*********************************** ***********\n"); printf("执行:"); scanf("%d",&flag); switch(flag) { case(1): printf("多项式a:");PrintPolyn(pa); printf("多项式b:");PrintPolyn(pb);break; case(2): pc=AddPolyn(pa,pb); printf("多项式a+b:");PrintPolyn(pc); DestroyPolyn(pc);break; case(3): pd=SubtractPolyn(pa,pb); printf("多项式a-b:");PrintPolyn(pd); DestroyPolyn(pd);break; case(4): pf=MultiplyPolyn(pa,pb); printf("多项式a*b:");PrintPolyn(pf); DestroyPolyn(pf);break; case(5): DevicePolyn(pa,pb); break; case(6): DestroyPolyn(pa); DestroyPolyn(pb); printf("成功销毁2个一元二项式\n"); printf("\n接下来要执行的操作:\n1 重新创建2个一元二项式 \n2 退出程序\n"); printf("执行:"); scanf("%d",&i); if(i==1) { // Polyn pa=0,pb=0,pc,pd,pf;//定义各式的头指针,pa与pb在使用前付初值NULL printf("请输入a的项数:"); scanf("%d",&m); pa=CreatePolyn(pa,m);// 建立多项式a printf("请输入b的项

数据结构课程设计多项式运算

#include #include #include"malloc.h" #define OK 1 #define ERROR 0 #define OVERFLOW -1 #define NULL 0 typedef int Status; typedef struct ElemType{ float coef; //多项式系数 int exp; //多项式指数 }ElemType;//数据类型 typedef struct Polynomial{ ElemType data; struct Polynomial *next; }*Polyn,Polynomial;//多项式结构体 void Insert(Polyn p,Polyn head) { /*将新的结点插入链表,如果系数为零,则释放该结点; 如果指数为新时将结点直接插入;否则查找插入位置, 方法:比较该结点指数与首元结点及其他结点的指数, 直到该结点指数大于等于链表内某结点的指数,相等则合并这两项;大于则插入到其前驱*/ if(p->data.coef==0) {free(p);p=NULL;} //如果插入项的系数为零时,释放其结点将其删除

else { Polyn q1,q2; q1=head; q2=head->next; while(q2&& p->data.exp < q2->data.exp) { //查找多项式某项的插入位置,使多项式按指数降幂排列 q1=q2; q2=q2->next; } if(q2&& p->data.exp == q2->data.exp) { //将多项式指数相同相进行合并 q2->data.coef += p->data.coef; free(p); if(!q2->data.coef) { //如果多项式的系数为零的话,将其删除即释放期结点 q1->next=q2->next; free(q2); } } else { //如果是新建的多项式,指数为新时将结点插入 p->next=q2; q1->next=p; } } }

数据结构中实现一元多项式简单计算

数据结构中实现一元多项式简单计算: 设计一个一元多项式简单的计算器。 基本要求: 一元多项式简单计算器的基本功能为: (1)输入并建立多项式; (2)输出多项式; (3)两个多项式相加,建立并输出和多项式; (4)两个多项式相减,建立并输出差多项式; #include #include #define MAX 20 //多项式最多项数 typedef struct//定义存放多项式的数组类型 { float coef; //系数 int exp; //指数 } PolyArray[MAX]; typedef struct pnode//定义单链表结点类型 { float coef; //系数 int exp; //指数 struct pnode *next; } PolyNode; void DispPoly(PolyNode *L) //输出多项式 { PolyNode *p=L->next; while (p!=NULL) { printf("%gX^%d ",p->coef,p->exp); p=p->next; } printf("\n"); } void CreateListR(PolyNode *&L,PolyArray a,int n) //尾插法建表 { PolyNode *s,*r;int i; L=(PolyNode *)malloc(sizeof(PolyNode)); //创建头结点 L->next=NULL; r=L; //r始终指向终端结点,开始时指向头结点for (i=0;i

数据结构-多项式

一.实验目的: 理解线性表的基本逻辑结构,完成链表及循环链表的实现 通过实验进一步理解线性表的逻辑结构和存储结构,提高使用理论知识指导解决实际问题的能力,熟练掌握链表的实际应用。 二.实验内容: 题目:一元多项式运算 问题描述: 设计算法实现一元多项式的简单运算。 基本要求: (1)输入并建立多项式; (2)输出多项式; (3)多项式加法 (4)多项式减法。 测试数据: (1)(2x+5x8-3.1x11)+(7-5x8+11x9)=(-3.1x11+11x9+2x+7) (2)(6x-3-x+4.4x2-1.2x9)-(―6x―3-+5.4x2-x2+7.8x15) =(―7.8x15―1.2x9+12x―3―x) (3)(1+x+x2+x3+x4+x5)+(―x3―x4)=(1+x+x2+x5) (4)(x+x3)+(―x―x3)=0 (5)(x+x100)+(x100+x200)=(x+2x100+x200) (6)(x+x2+x3)+0=x+x2+x3 三. 实验方案(程序设计说明)

(一)算法设计思路: 1.将两个多项式的系数和指数分别存放在新建的两个链表中; 2.其中一个链表A的指针不动,遍历另一个链表B,指数相等 时系数相加,删除该数,链表B从头开始,链表A移向下个 数据域; 3.直到链表B为空或者链表A遍历完成结束。 (二)算法流程图:

(三)界面设计说明: 请输入多项式的长度: 开始 输入多项式长 度N 以及系数 m,指数n A →n= B →n? Y N j++ 系数相加存放在A 表 i++ 结束 创建链表A ,B ,链表A 从i=0 开始循环,链表B 从j=0开始 i>N? N Y i>N? N Y

数据结构实验一一元多项式相加

数据结构实验报告实验一:一元多项式相加 姓名:周成 学号: 专业:软件工程 任课教师:马慧珠 2013年12 月01 日

1.实验名称: 一元多项式相加 2.实验目的: 如何使用C语言实现链表的说明、创建以及结点的插入和删除等操作。 3.实验要求: 对一元多项式能实现输入、输出,以及两个一元多项式相加及结果显示。 4.实验内容: 一元多项式的表示在计算机内用链表来实现,同时为了节省存储空间,只存储其中非零的项,链表中的每个节点存放多项式的系数非零项。它包含三个域,分别存放多项式的系数,指数,以及指向下一个项的指针。根据一元多项式相加的运算规则:对于两个一元多项式中所有指数相同的项,对应系数相加,若其和不为零,则构成“和多项式”中的一项,对于两个一元多项式中所有指数不相同的项,则分别复抄到“和多项式”中去。 核心算法PolyAdd是把分别由pa和pb所指的两个多项式相加,结果为pa所指的多项式。运算规则如下:相加时,首先设两个指针变量qa和qb分别从多项式的首项开始扫描,比较qa和qb所指结点指数域的值,可能出现下列三种情况之一:

(1)qa->exp大于qb->exp,则qa继续向后扫描。 (2)qa->exp等于qb->exp,则将其系数相加。若相加结果不为零,将结果放入qa->coef中,并删除qb所指结点,否则同时删除qa和qb所指结点。 然后qa、qb继续向后扫描。 (3)qa->exp小于qb->exp,则将qb所指结点插入qa所指结点之前,然后qa、qb继续向后扫描。 扫描过程一直进行到qa或qb有一个为空为止,然后将有剩余结点的链表接在结果表上。所得pa指向的链表即为两个多项式之和。 5.实验程序代码及运行结果: #include"" #include<> #include<> #include<> #include<> #define NULL 0 typedef struct NODE {

数据结构一元多项式的加减乘

#ifndef _POL YNOMIAL_H #define _POL YNOMIAL_H #include using namespace std; #include //#define ElemType char typedef struct // 项的表示,多项式的项作为LinkList的数据元素 { float coef; // 系数 int expn; // 指数 }term, ElemType; typedef struct LNode // 结点类型 { ElemType data; struct LNode *next; }LNode,*Link,*Position; typedef struct LinkList // 链表类型 { Link head,tail; // 分别指向线性链表中的头结点和最后一个结点 int len; // 指示当前线性链表中数据元素的个数 }LinkList; typedef LinkList polynomial; void InitList(LinkList &P); void CreatPolyn(polynomial &P,int m); void DestroyPolyn(polynomial &P); void CreatePolyn(polynomial &P,int m);//建立表示一元多项式的有序链表P void DestroyPolyn(polynomial &P);//销毁一元多项式P void PrintPolyn(polynomial P);//打印 int PolyLength(polynomial P);//项数 void AddPolyn(polynomial &Pa,polynomial &Pb);//相加运算 void SubtractPolyn(polynomial &Pa,polynomial &Pb);//相减运算 void MultiplyPolyn(polynomial &P,polynomial &Pa,polynomial &Pb);//相乘运算 int cmp(term a,term b);//依a的指数值<(或=)(或>)b的指数值,分别返回-1,0,+1 int LocateElemP(LinkList L,ElemType e,Position *q, int(*compare)(ElemType,ElemType)); int MakeNode(Link *p,ElemType e); int InsFirst(LinkList *L,Link h,Link s);

数据结构一元多项式的计算

课程设计成果 学院: 计算机工程学院班级: 13计科一班 学生姓名: 学号: 设计地点(单位): 设计题目:一元多项式的计算 完成日期:年月日 成绩(五级记分制): _________________ 教师签名:_________________________ 目录 1 需求分析 ......................................................................... 错误!未定义书签。 2 概要设计 ......................................................................... 错误!未定义书签。 2.1一元多项式的建立 ............................................................... 错误!未定义书签。 2.2显示一元多项式 ................................................................... 错误!未定义书签。 2.3一元多项式减法运算 ........................................................... 错误!未定义书签。 2.4一元多项式加法运算 ........................................................... 错误!未定义书签。 2.5 设计优缺点.......................................................................... 错误!未定义书签。3详细设计 .......................................................................... 错误!未定义书签。 3.1一元多项式的输入输出流程图........................................... 错误!未定义书签。 3.2一元多项式的加法流程图................................................... 错误!未定义书签。 3.3一元多项式的减法流程图.................................................. 错误!未定义书签。 3.4用户操作函数....................................................................... 错误!未定义书签。4编码 .................................................................................. 错误!未定义书签。5调试分析 .......................................................................... 错误!未定义书签。4测试结果及运行效果...................................................... 错误!未定义书签。5系统开发所用到的技术.................................................. 错误!未定义书签。参考文献 ............................................................................. 错误!未定义书签。附录全部代码................................................................... 错误!未定义书签。

数据结构-多项式相加

数据结构课程设计 2012年12月 班级:XXX 学号:XXX 姓名: XXX 指导教师:XXX

一元稀疏多项式计算器 【问题描述】 设计一个一元稀疏多项式简单计算器 【基本要求】 一元多项式简单计算器的基本功能是: 1,输入并建立多项式; 2,输出多项式,输出形式为整数序列:n,c1,e1,c2,c2,...,cn,en,其中n是多项式的项数,ci和ei分别是第i项的系数和指数,序列按指数降序排列; 3,多项式a和b相加,建立多项式a+b; 4,多项式a和b相减,建立多项式a-b. 【算法设计思想】 ①一般情况下的一元n次多项式可写成pn(x)=p1xe1+p2xe2+……+pmxem 其中,p1是指数为ei的项的非零系数,且满足0≦e1

【实现提示】 用带表头结点的单链表存储多项式。 【程序代码】 #include #include typedef struct node { float coef; int expn; struct node *next; }Lnode, *polynmial; void create(polynmial &L); //输入并建立多项式L void display(polynmial L); //显示,输出多项式L void sort(polynmial &L); //多项式L按指数排序 void reverse(polynmial &L); //逆置 void select(); //用户选择加减操作 void add(polynmial La, polynmial Lb, polynmial &Lc); //多项式La,Lb相加void subtract(polynmial La, polynmial Lb, polynmial &Ld); //多项式La减去Lb,结果给Ld void create(polynmial &L) //输入并建立多项式L { int i, n; static struct node *p; scanf("%d", &n); L = (struct node *)malloc (sizeof(struct node)); L->next = NULL; for(i = 0; i < n; i++) { p = (struct node *)malloc(sizeof(struct node)); scanf("%f %d", &p->coef, &p->expn); p->next = L->next; L->next = p; } } void display(polynmial L)//显示,输出多项式L { struct node *p, *q; int flag = 0; int k = 0; q = L->next; while(q)

C语言一元多项式计算

C语言一元多项式计算集团标准化工作小组 #Q8QGGQT-GX8G08Q8-GNQGJ8-MHHGN#

#include <> #include <> #include <> #define LEN sizeof(node) //结点构造 typedef struct polynode { int coef; //系数 int exp; //指数 struct polynode *next; }node; node * create(void) { node *h,*r,*s; int c,e; h=(node *)malloc(LEN); r=h; printf("系数:"); scanf("%d",&c); printf("指数:"); scanf("%d",&e); while(c!=0) { s=(node *)malloc(LEN); s->coef=c; s->exp=e; r->next=s; r=s; printf("系数:"); scanf("%d",&c); printf("指数:"); scanf("%d",&e); } r->next=NULL; return(h);

} void polyadd(node *polya, node *polyb) { node *p,*q,*pre,*temp; int sum; p=polya->next; q=polyb->next; pre=polya; while(p!=NULL&&q!=NULL) { if(p->exp>q->exp) { pre->next=p; pre=pre->next; p=p->next; } else if(p->exp==q->exp) { sum=p->coef+q->coef; if(sum!=0) { p->coef=sum; pre->next=p;pre=pre->next;p=p->next; temp=q;q=q->next;free(temp); } else { temp=p->next;free(p);p=temp; temp=q->next;free(q);q=temp; } } else { pre->next=q; pre=pre->next; q=q->next; } } if(p!=NULL) pre->next=p; else pre->next=q; } void print(node * p) {

数据结构 多项式 实验报告

数据结构实验报告 实验名称:实验一——多项式的实现 学生姓名: 班级: 班内序号: 学号: 日期:2011年10月29日 1.实验要求 实验目的: 1.熟悉C++语言的基本编程方法,掌握集成编译环境的调试方法 2.学习指针、模板类、异常处理的使用 3.掌握线性表的操作的实现方法 4.学习使用线性表解决实际问题的能力 实验内容: 利用线性表实现一个一元多项式Polynomial f(x) = a0 + a1x + a2x2 + a3x3+ … + a n x n 要求: 1.能够实现一元多项式的输入和输出 2.能够进行一元多项式相加 3.能够进行一元多项式相减 4.能够计算一元多项式在x处的值 5.能够计算一元多项式的导数(选作) 6.能够进行一元多项式相乘(选作) 7.编写测试main()函数测试线性表的正确性 2. 程序分析 由于多项式是线性结构,故选择线性表来实现,在这个程序中我采用的是单链表结构,每个结点代表一个项,多项式的每一项可以用其系数和指数唯一的表示。如果采用顺序存储,那么对于结点的插入和删除的操作会比较麻烦,而且顺序表的结点个数固定,对于可能发生的情况无法很好的处理,而采用链表就会简单许多,还能自由控制链表的长度。 两个多项式要进行多次的计算,为了保护原始的数据,方便进行以后的计算,故选择把结果存储在一个新建的链表里。 本程序完成的主要功能: 1.输入和输出:需要输入的信息有多项式的项数,用来向系统动态申请内存;多项式

各项的系数和指数,用来构造每个结点,形成链表。输出即是将多项式的内容 向屏幕输出。 2.多项式相加与相减:多项式的加减要指数相同即是同类项才能实现,所以在运算时 要注意判断指数出现的各种不同的情况,分别写出计算方法。将每项运算得到 的结果都插入到新的链表中,形成结果多项式。 3.多项式的求导运算:多项式的求导根据数学知识,就是将每项的系数乘以指数,将 指数减1即可,将每项得到的结果插入到结果多项式的链表中。 4.多项式在某点的值:由用户输入x的值,然后求出每项的值相加即可。 2.1 存储结构 本程序采用的存储结构是单链表结构,其定义的结点包括三部分:系数、指数以及下一个结点的地址。示意图如下: 1.输入多项式 ·自然语言描述: 1.设置多项式的项数n; 2.按照多项式的项数申请动态数组coef[]和expn[]存储多项式的系数和指数; 3.按照指数递增的次序输入各项的系数以及指数,分别存入coef和expn; 4.再将输入的系数以及指数赋给每一个结点的coef和expn域; 5.利用头插法将每个结点加入链表。 ·伪代码: 1.输入项数n; 2.float* coef1=new float[n1]; int* expn1=new int[n1]; 3.运用for循环,循环n次 3.1 term* s=new term; 3.2 s->coef=coef[i]; 3.3 s->expn=expn[i]; 3.4 r->next=s; 3.5 r=s; 4. 运用头插法将结点插入链表。 时间复杂度: 空间复杂度: 2.输出多项式 ·自然语言描述: 1.获取头结点; 2.循环n-1次(n为多项式的项数) 2.1将指针的指向后移; 2.2依照多项式的各种情况,设置输出方式 2.2.1 系数为1且指数不为1和0,输出x^expn+; 2.2.2 系数不为0且指数为0,输出(coef)+; 2.2.3 系数不为0且指数为1,输出(coef)x+;

一元多项式的计算数据结构课程设计

一元多项式的计算—加,减 摘要(题目)一元多项式计算 任务:能够按照指数降序排列建立并输出多项式; 能够完成两个多项式的相加、相减,并将结果输入; 目录 1.引言 2.需求分析 3.概要设计 4.详细设计 5.测试结果 6.调试分析 7.设计体会 8.结束语 一:引言: 通过C语言使用链式存储结构实现一元多项式加法、减法和乘法的运算。按指数

降序排列。 二:需求分析 建立一元多项式并按照指数降序排列输出多项式,将一元多项式输入并存储在内存中,能够完成两个多项式的加减运算并输出结果 三:概要设计 存储结构:一元多项式的表示在计算机内可以用链表来表示,为了节省存储空间,只存储多项式中系数非零的项。链表中的每一个结点存放多项式的一个系数非零项,它包含三个域,分别存放该项的系数、指数以及指向下一个多项式项结点的指针。创建一元多项式链表,对一元多项式的运算中会出现的各种可能情况进行分析,实现一元多项式的相加、相减操作。 1.单连表的抽象数据类型定义: ADT List{ 数据对象:D={ai|ai∈ElemSet,i=1,2,…,n,n≥0} 数据关系:R1={| ai-1, ai∈D,i=2,…,n} 基本操作: InitList(&L) //操作结果:构造一个空的线性表 CreatPolyn(&L) //操作结果:构造一个以单连表存储的多项试 DispPolyn(L) //操作结果:显示多项试 Polyn(&pa,&pb) //操作结果:显示两个多项试相加,相减的结果 } ADT List 2.本程序包含模块: typedef struct LNode //定义单链表 { }LNode,*LinkList; void InitList(LinkList &L) //定义一个空表 { } void CreatPolyn(LinkList &L) //用单链表定义一个多项式 { } void DispPolyn(LinkList L) //显示输入的多项式

数据结构一元多项式报告

一元多项式计算: 程序要求: 1)、能够按照指数降序排列建立并输出多项式; 2)、能够完成两个多项式的相加、相减,并将结果输入。 概要设计: 1.功能:将要进行运算的多项式输入输出。 2.数据流入:要输入的多项式的系数与指数。 3.数据流出:合并同类项后的多项式。 4.程序流程图:多项式输入流程图如图3.2.1所示。 5.测试要点:输入的多项式是否正确,若输入错误则重新输入 2、多项式的加法 (1)功能:将两多项式相加。 (2)数据流入:输入函数。 (3)数据流出:多项式相加后的结果。 (4)程序流程图:多项式的加法流程图如图3.2.2所示。 (5)测试要点:两多项式是否为空,为空则提示重新输入,否则,进行运算。

3、多项式的减法 (1)功能:将两多项式相减。 (2)数据流入:调用输入函数。 (3)数据流出:多项式相减后的结果。 (4)程序流程图:多项式的减法流程图如图3.2.3所示。 (5)测试要点:两多项式是否为空,为空则提示重新输入,否则,进行运算。

详细代码: #include #include #include using namespace std; struct Node { float coef;//结点类型 int exp; }; typedef Node polynomial;

struct LNode { polynomial data;//链表类型 LNode *next; }; typedef LNode* Link; void CreateLink(Link &L,int n); void PrintList(Link L); void PolyAdd(Link &pc,Link pa,Link pb); void PolySubstract(Link &pc,Link pa,Link pb); void CopyLink(Link &pc,Link pa); void PolyMultiply(Link &pc,Link pa,Link pb); int JudgeIfExpSame(Link pa,Link e); void DestroyLink(Link &L); int CompareIfNum(int i); void DestroyLink(Link &L) { Link p; p=L->next; while(p) { L->next=p->next; delete p; p=L->next; } delete L; L=NULL; } //创建含有n个链表类型结点的项,即创建一个n项多项式void CreateLink(Link &L,int n) { if(L!=NULL) { DestroyLink(L); } Link p,newp; L=new LNode; L->next=NULL; (L->data).exp=-1;//创建头结点 p=L; for(int i=1;i<=n;i++) { newp=new LNode; cout<<"请输入第"<

一元多项式计算器

一元多项式计算器 目录 摘要 (1) 1绪论 (1) 2系统分析 (1) 2.1功能需求 (1) 2.2数据需求 (1) 2.3性能需求 (1) 3总体设计 (2) 3.1系统设计方案 (2) 3.2功能模块设计 (2) 4详细设计 (3) 4.1建立多项式 (4) 4.2多项式相加 (4) 4.3多项式相减 (5) 4.4多项式相乘 (5) 4.5计算器主函数 (6) 5调试与测试 (7) 5.1调试 (7) 5.2测试 (8) 6结论 (9) 结束语 (9) 参考文献 (9) 附录1-用户手册 (10) 附录2-源程序 (12)

摘要 随着生活水平的提高,现代科技也日益发达。日常生活中多位计算再所难免,因此设计一个简单计算器可解决许多不必要的麻烦。 开发这样一个程序主要运用了C的结点,链表等方面知识。系统主要实现了多项式的建立,多项式的输入输出,以及多项式加减乘等运算。 报告主要从计算器的程序段,对输入输出数据的要求,计算器的性能,以及总体的设计来介绍此计算器程序的实现过程。 关键词:多项式;链表;结点 1绪论 随着日益发达的科技,计算器已应用于各行各业。设计一个计算器需要运用C中多方面知识,更是以多项式的建立,输入输出,以及结点,链表为主。(扩充) 任务书。。。。。 2系统分析 2.1 功能需求 多项式的建立多项式输入输出多项式加减乘等运算 2.2数据需求 在输入过程中,首先要确定输入的数据,数据不能是字母,只能是数字。不能连续输入数据,必须按要求配以空格输入要计算的数据。 (1) 链节节点数字 (2) 数字 2.3 性能需求 系统必须安全可靠,不会出现无故死机状态,速度不宜过慢。

一元多项式计算(数据结构课程设计)

一元多项式计算(数据结构课程设计)

一、系统设计 1、算法思想 根据一元多项式相加的运算规则:对于两个一元多项式中所有指数相同的项,对应指数相加(减),若其和(差)不为零,则构成“和(差)多项式”中的一项;对于两个一元多项式中所有指数不相同的项,则分别写到“和(差)多项式”中去。 因为多项式指数最高项以及项数是不确定的,因此采用线性链表的存储结构便于实现一元多项式的运算。为了节省空间,我采用两个链表分别存放多项式a 和多项式b,对于最后计算所得的多项式则利用多项式a进行存储。主要用到了单链表的插入和删除操作。

(1)一元多项式加法运算 它从两个多项式的头部开始,两个多项式的某一项都不为空时,如果指数相等的话,系数就应该相加;相加的和不为零的话,用头插法建立一个新的节点。P 的指数小于q的指数的话就应该复制q的节点到多项式中。P的指数大于q的指数的话,就应该复制p节点到多项式中。当第二个多项式空,第一个多项式不为空时,将第一个多项式用新节点产生。当第一个多项式空,第二个多项式不为空时,将第二个多项式用新节点产生。 (2)一元多项式的减法运算 它从两个多项式的头部开始,两个多项式的某一项都不为空时,如果指数相等的话,系数就相减;相加的和不为零的话,用头插法建立一个新的节点。p的指数小于q的指数的话,就应该复制q的节点到多项式中。P的指数大于q的指数的话就应该复制p的节点到多项式中,并且建立的节点的系数为原来的相反数;当第二个多项式空,第一个多项式不为空时,将第一个多项式用新节点产生。当第一个多项式空,第二个多项式不为空时,将第二个多项式用新节点产生,并且建立的节点的系数为原来的相反数。 2、概要设计 (1)主函数流程图: (注:a代表第一个一元二次方程,b代表第二个一元二次方程)

数据结构——一元多项式的建立与相加

#include #include using namespace std; typedef struct PolyNode { int coef; //系数 int expn; //指数 struct PolyNode *next; } *PNode; //多项式结点的指针 void InitPoly(PNode &head,PNode &p) { head=(PNode)malloc(sizeof(struct PolyNode)); head->next=NULL; head->coef=0; head->expn=-1; p=head; } void CreatePoly(PNode &head,int a,int n) { PNode s; s=(PNode)malloc(sizeof(struct PolyNode)); //建立新的结点s->coef=a; s->expn=n; s->next=NULL; head->next=s; head=s; } void PrintPoly(PNode head) { int i=1;//控制第一对系数指数的显示 head=head->next;//指向表头结点的下一个 PNode p; p=head; while ((p->next)!=NULL) { if(i) //显示第一对的时候是不需要显示加号的 { if (p->expn==1) cout<coef<<"x"; else if (p->expn==0) cout<coef<

else cout<coef<<"x^"<expn; i=0; } else { if (p->expn==1) cout<coef<<"+x"; else if (p->expn==0) cout<<"+"<coef<coef<<"x^"<expn; } p=p->next; } cout<next; pb=pb->next; p=pc; while (pa!=NULL && pb!=NULL) { if (pa->expn>pb->expn) { s=(PNode)malloc(sizeof(struct PolyNode)); s->coef=pa->coef; s->expn=pa->expn; s->next=NULL; p->next=s; p=s; pa=pa->next; } else if (pa->expnexpn) { s=(PNode)malloc(sizeof(struct PolyNode)); s->coef=pb->coef; s->expn=pb->expn; s->next=NULL; p->next=s; p=s; pb=pb->next; }

相关文档
相关文档 最新文档