赞
踩
数据结构课程设计任务书 |
学生姓名: 专业班级: 指导教师: 工作单位: |
题 目: 一元稀疏多项式计算器 基础要求: 一元稀疏多项式简单计算器的基本功能是: (1) 输入并建立多项式 ; (2) 输出多项式,输出形式为整数序列:n,cl,el,c2,e2,…,cn,en,其中n是多项式的项数,ci 和ei,分别是第 i 项的系数和指数,序列按指数降序排列; (3) 多项式a和b相加,建立多项式a +b; (4) 多项式a和b相减,建立多项式a -b 。 主要任务: (1)设计一个一元稀疏多项式简单计算器。 (2)用带表头结点的单链表存储多项式。 (3)撰写课程设计报告 |
时间安排: 内容 天数 地点 构思及收集资料 1 机房 编码与调试 3 机房 撰写论文 1 图书馆、机房 |
指导教师签名: 年 月 日 |
目录
一元稀疏多项式计算器............................... 1
一、问题分析和任务定义.............................. 1
1.1 课程目的....................................... 1
1.2 任务需求....................................... 1
二、 数据结构的选择和概要设计........................ 2
2.1一元多项式的建立................................ 2
2.2创建一个一元多项式............................... 2
2.3 多项式相加...................................... 2
2.4 多项式相减...................................... 3
三、 编码实现..................................... 4
3.1一元多项式的建立................................ 4
3.2创建一个一元多项式............................... 4
3.3打印多项式...................................... 5
3.4 多项式相加...................................... 5
3.5 多项式相减...................................... 6
四、实验结果测试结果及其分析......................... 7
4.1调试分析........................................ 7
五、参考文献..................................... 10
完整资料私信我:
一元稀疏多项式计算器
设计一个一元稀疏多项式简单计算器。
基本要求:
(1) 输入并建立多项式 ;
(2) 输出多项式,输出形式为整数序列:n,cl,el,c2,e2,…,cn,en,其中n是多项式的项数,ci 和ei,分别是第 i 项的系数和指数,序列按指数降序排列;
(3) 多项式a和b相加,建立多项式a +b;
(4) 多项式a和b相减,建立多项式a -b 。
测试数据:
(1)(2x+5x8-3.1x11) + (7-5x8+11x9)=(-3.lx11+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
(7) 互换上述测试数据中的前后两个多项式
使用带头结点的单链表存储多项式,插入查找和删除较为方便。数据域中存 储系数和指数,指针域指向下一个节点的位置。
m
,新建立一个节点node
,用来存贮读入的系 数coef
和项数expn
。数值。
(p1->expn与p2->expn),有下列三种情况:
*若和不为0,则把p1与p2的系数相加,存到p3指向的节点,再把p1或p2的指数存到p3中,全部向后移动一个节点。
*若和为0,则p1和p2向后移动一个节点。
多项式的相减实现起来步骤相对简单,只需要把多项式Pb中每一项的系数取反,再相加就可以了。
结构体的定义
void PrintPolyn(LS *h)
{
LS *p = h;
int count = 1; //设置一个变量用于控制打印符号
while (p->next != NULL)
{
p = p->next;
if (count != 1 && p->coef > 0) //打印符号
{
printf("+");
}
if (p->expn == 0) // 如果指数为0只打印系数
{
printf("%g", p->coef);
}
else if (p->expn == 1)
{
printf("%gx", p->coef);
}
else
{
printf("%gx^%d", p->coef, p->expn);
}
count++;
}
printf("\n");
}
多项式相加的代码如下:
注:本次测试多项式的输入和输出都是按照指数的降序排列的。
测试数据:
(1)(2x+5x8-3.1x11) + (7-5x8+11x9)=(-3.lx11+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)
(4)(x+x3)+(-x-x3)=0
(6)(x+x2+x3)+0=x+x2+x3
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。