文档库 最新最全的文档下载
当前位置:文档库 › 《程序语言课程设计 - 一元多项式简单的计算器》..

《程序语言课程设计 - 一元多项式简单的计算器》..

《程序语言课程设计 - 一元多项式简单的计算器》..
《程序语言课程设计 - 一元多项式简单的计算器》..

西安文理学院软件学院课程设计报告

设计名称:程序语言课程设计

设计题目:一元多项式简单的计算器

学生学号:1402120135

专业班级:软件学院一班

学生姓名:张文东

学生成绩:

指导教师(职称):袁溪(讲师)

课题工作时间:2013.12.9 至2013.12.23

软件学院课程设计任务书

指导教师:院长:

日期:2013年12月9日

软件学院课程设计进度安排表

学生姓名:张文东学号:1402120135 专业:软件工程班级:一班

指导教师签名:

2013年12月11日

成绩评定表

学生姓名:张文东学号:1402120135 专业:软件工程班级:一班

摘要

摘要:随着科技的不断发展,人们生活水平的不断提高,方便、高效、快捷成为了人们所追求的主要目标,面对一些复杂的技术总会花费大量时间进行计算,因此有一个多项式功能的计算器是很有必要的。

开发这样一个程序需要用到C结点、链表方面的知识,系统分为多项式的输入输出、多项式的加法、多项式的减法、多项式的乘法四个模块。

该报告主要是通过系统的程序段、程序设计的要求以及计算器的功能来介绍该计算器实现过程。

关键字:多项式;C语言;结点;链表

目录

目录 (1)

第一章课题背景 (2)

1.1绪论 (2)

1.2主要内容 (2)

第二章设计简介及设计方案论述 (3)

2.1系统分析 (3)

2.2总体设计 (3)

第三章详细设计 (5)

3.1建立多项式 (5)

3.2多项式相加 (7)

3.3多项式相减 (9)

3.4多项式相乘 (10)

主要代码如下: (12)

主要代码如下: (14)

第四章设计结果及分析 (17)

4.1调试与测试 (17)

4.2运行结果 (19)

4.3结果分析 (21)

总结 (22)

参考文献 (23)

附录 (24)

第一章课题背景

1.1 绪论

随着科技的进步,社会的不断发展,计算器已普遍应用于各行各业,为了帮助人们提高工作效率,节约运算时间,设计一个多功能的计算器是很有必要的,在此设计一个多项式计算器可以很方便的对多项式相加、相减、相乘,对提高人们的运算效率很有帮助。

一个计算器需要用到C多方面的知识,要实现多项式的建立和输入输出等功能,必须要熟练的掌握C,在此尤其是链表和结点。

1.2 主要内容

用C语言实现多项式的输入输出和多项式的加减乘等运算,其中主要用到链表和结点的相关知识,具体功能如下:

1)输入并建立多项式;

2)输出多项式;

3)两个多项式相加,输出和多项式;

4)两个多项式相减,输出差多项式。

第二章设计简介及设计方案论述

2.1 系统分析

2.1.1 功能需求

多项式的建立多项式的输入输出多项式的加减乘等运算

2.1.2 数据需求

在输入过程中,首先要给定输入的数据,数据只能是数字,不能是字母或其他,不能连续输入数据,必须要求以空格分开要输入的数据。

2.1.3 系统需求

系统必须安全可靠,不会出现无故死机状态,运算速度要快。

2.2 总体设计

2.2.1 系统设计方案

采用菜单设计,选择你需要的功能,用单链表储存你输入的数据。

(1) 菜单

菜单包括计算器加减乘等功能的选择

(2) 文件保存方式

运用带头节点的单链表储存多项式

(3) 抽象数据类型定义

主要定义多项式的系数和指数。系数项用浮点类型定义,指数项用整型定义

(4) 存储结构

采用链式结构,建立链表储存输入的多项式

(5) 算法设计

运用链表知识,建立链表,给链表分配一定量的存储空间,查找链表,插入链表和链表的连接

2.2.2 功能模块设计

一元多项式计算器

图 2-1 功能模块设计

第三章详细设计

一元多项式计算器主要分为4大部分,多项式建立,多项式加法,多项式减法和多项式乘法。多项式的建立主要需要建立新链表,并分配给这个新链表一定量的存储空间,分配的存储空间内进行运算;多项式加减乘等运算主要运用了链表的建立,链表存储空间分配,链表的查找,插入与连接进行计算。

3.1 建立多项式

此阶段是多项式的建立,可以对计算器进行输入输出等功能。主要运用链表方面的知识如图3-1所示:

图 3-1 多项式的建立

主要代码如下:

PLOY *creat(char ch) //建立多项式

{

PLOY *head,*inpt;

float x;

int y;

head=(PLOY *)malloc(sizeof(PLOY));

head->next=NULL;

printf("请输入一元多项式%c:(格式是:系数指数;以0 0 结束!)\n",ch);

scanf("%f %d",&x,&y);

while(x!=0)

{

inpt=(PLOY *)malloc(sizeof(PLOY));

inpt->coef=x;

inpt->expn=y;

inpt->next=NULL;

insert(head,inpt);

printf("请输入一元多项式%c:(以0 0 结束!)\n",ch);

scanf("%f %d",&x,&y);

}

return head;

}

3.2 多项式相加

此阶段是计算器的加法运用功能,对你输入的多项式进行相加计算,主要运用了链表,及链表的插入等知识,如图3-2所示:

图 3-2 多项式相加

主要代码如下:

PLOY *addPLOY(PLOY *head,PLOY *pre) //多项式相加{

PLOY *inpt;

int flag=0;

while(flag==0)

{

if(pre->next==NULL)

flag=1;

else

{

pre=pre->next;

inpt=(PLOY *)malloc(sizeof(PLOY));

inpt->coef=pre->coef;

inpt->expn=pre->expn;

inpt->next=NULL;

insert(head,inpt);

}

}

return head;

3.3 多项式相减

此阶段是计算器的减法运用功能,对你输入的多项式进行相减计算,主要运用了链表,链表查询,及链表的插入等知识,如图 3-3所示:

图 3-3 多项式相减

主要代码如下:

PLOY *minusPLOY(PLOY *head,PLOY *pre) //多项式相减

{

PLOY *inpt;

int flag=0;

while(flag==0)

{

if(pre->next==NULL)

flag=1;

else

{

pre=pre->next;

inpt=(PLOY *)malloc(sizeof(PLOY));

inpt->coef=0-pre->coef;

inpt->expn=pre->expn;

inpt->next=NULL;

insert(head,inpt);

}

}

return head;

}

3.4 多项式相乘

此阶段是计算器的乘法运用功能,对你输入的多项式进行相乘计算,主要运用了链表,链表查询,及链表的插入等知识,如图3-4所示:

图 3-4多项式相乘

主要代码如下:

PLOY *byPLOY(PLOY *head1,PLOY *head2) //多项式相乘{

PLOY *inpt,*res,*pre;

int flag=0;

res=(PLOY *)malloc(sizeof(PLOY));

res->next=NULL;

head1=head1->next;

pre=head2;

while(flag==0)

{

if(pre->next==NULL)

{

pre=head2;

head1=head1->next;

continue;

}

if(head1==NULL)

{

flag=1;

continue;

}

pre=pre->next;

inpt=(PLOY *)malloc(sizeof(PLOY));

inpt->coef=pre->coef*head1->coef;

inpt->expn=pre->expn+head1->expn;

inpt->next=NULL;

insert(res,inpt);

}

return res;

}

3.5 计算器主函数

主要代码如下:

void main()

{

PLOY *f,*g;

int sign=-1;

start();

while(sign!=0)

{

scanf("%d",&sign);

switch(sign)

{

case 0:

break;

case 1:

{

printf("你选择的操作是多项式相加:\n");

f=creat('f');

printf("f(x)=");

print(f);

g=creat('g');

printf("g(x)=");

print(g);

printf("--------------------\n\n");

printf("两个多项式相加结果为:\n\n");

printf(" F(x)=f(x)+g(x)=");

f=addPLOY(f,g);

print(f);

printf("\n--------------------\n");

sign=-1;

start();

break;

}

case 2:

{

printf("你选择的操作是多项式相减:\n");

f=creat('f');

printf("f(x)=");

print(f);

g=creat('g');

printf("g(x)=");

print(g);

printf("--------------------\n\n");

printf("两个多项式相减结果为:\n\n");

printf(" F(x)=f(x)-g(x)=");

f=minusPLOY(f,g);

print(f);

printf("\n--------------------\n");

sign=-1;

start();

break;

}

case 3:

{

printf("你选择的操作是多项式相乘:\n");

f=creat('f');

printf("f(x)=");

print(f);

g=creat('g');

printf("g(x)=");

print(g);

printf("--------------------\n\n");

printf("两个多项式相乘结果为:\n\n");

printf(" F(x)=f(x)*g(x)=");

f=byPLOY(f,g);

print(f);

相关文档