PTA 6-14 用单向链表完成多项式运算(35分)
输入两个多项式,计算它们的加、减及乘法, 将计算结果输出到屏幕上。
1) 输入:从键盘分两行分别输入两个多项式数据,每个多项式输入格式如下:
n a1 m1 a2 m2 a3 m3 . .. ai mi.... an mn
其中n为多项式系数为非零的项数,ai为系数,mi为指数, 它们都是整数,该输入数据所表达的多项式意义为(其中符号^表示幂次):
a1x^m1 + a2x^m2 + a3x^m3 + ...... + an x^mn
2)输出:先输出参与运算的两个多项式, 然后输出它们的运算结果,格式为:
要求:多项式输出时从幂次数高到低的顺序逐项输出,若任何一项的系数是0的话,请不要输出,除非所有的系数为0,则输出0。
函数接口定义:
void print_polynomial(polynomial *head);
本函数完成一个多项式的输出。题目要求的功能以及本函数具体涉及到多项式链表的创建以及多项式加、减和乘法运算所需的功能模块请在本函数实现之前一并自行完成,并将代码插入在合适的位置。
裁判测试程序样例:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct node
{
int coef; /* 系数 */
int exp; /* 指数 */
struct node *next;
} polynomial;
/* 提示:递交的答案将会自动插入此处 */
int main(void)
{
polynomial *polyA,*polyB;
polyA=create_polynomial(); /* 其中函数create_polynomial()用于读入并创建多项式A的链表,请自行实现 */
polyB=create_polynomial(); /* 读入并创建多项式B的链表 */
printf("A=");
print_polynomial(polyA); /* 输出多项式A */
printf("B=");
print_polynomial(polyB); /* 输出多项式B */
printf("A+B=");
print_polynomial(add_polynomial(polyA,polyB) );
/* 输出多项式加A+B 的结果, 其中函数add_polynomial(polyA,polyB)将返回A+B的多项式,请自行实现*/
printf("A-B=");
print_polynomial(subtract_polynomial(polyA,polyB) );
/* 输出多项式减A-B 的结果,其中函数subtract_polynomial(polyA,polyB)返回A-B的多项式,请自行实现*/
printf("A*B=");
print_polynomial(multiply_polynomial(polyA,polyB));
/* 输出多项式乘A*B 的结果,其中函数multiply_polynomial(polyA,polyB)返回A*B的多项式,请自行实现 */
return 0;
/* 请在这里填写答案 */
}
输入样例:
在这里给出一组输入。例如:
3 1 2 3 4 5 6
3 1 2 3 4 5 6
输出样例:
在这里给出相应的输出。例如(其中 x 是小写字母):
A=5x^6 +3x^4 +x^2
B=5x^6 +3x^4 +x^2
A+B=10x^6 +6x^4 +2x^2
A-B=0
A*B=25x^12 +30x^10 +19x^8 +6x^6 +x^4
有点坑的题目 卡了半天样例(机考写完的时候老师问我是不是搞错题意,然而并不是...这题真就要把函数全写了,并不是只写个输出函数)
输入要排序!!!我这里直接每次输入一个插入一次链表,也可以输入后链表排序, x^1 要输出成x,ax^0 要写成a,格式挺麻烦.... 当时太懒了用数组偷懒被老师锤了..... ⑧说了,我也觉得输出函数写得丑,因为看不下去然后改得好看些然后wa了就不想改了..
polynomial *create_polynomial()
{
int n;
scanf("%d", &n);
polynomial *head, *p, *t;
head = (polynomial *)malloc(sizeof(polynomial));
head->next = NULL;
/*输入排序*/
for (int i = 0; i < n; i++)
{
int coef, exp;
polynomial *cah;
scanf("%d%d", &coef, &exp);
t = head;
for (; t->next != NULL; t = t->next)
{
if (t->next->exp < exp)
{
cah = (polynomial *)malloc(sizeof(polynomial));
cah->coef = coef;
cah->exp = exp;
cah->next = t->next;
t->next = cah;
break;
}
else if (t->next->exp == exp)
{
t->next->coef += coef;
break;
}
}
if (!t->next)
{
cah = (polynomial *)malloc(sizeof(polynomial));
cah->coef = coef;
cah->exp = exp;
t->next = cah;
cah->next = NULL;
}
}
return head;
}
void print_polynomial(polynomial *head)
{
polynomial *p;
int flag = 0;
for (p = head->next; p != NULL; p = p->next)
{
if (!flag && p->coef != 0)
{
flag = 1;
if (p->coef > 0)
{
if (p->exp == 0)
printf("%d", p->coef);
else
{
p->coef == 1 ? printf("x") : printf("%dx", p->coef);
p->exp == 1 ? printf("") : printf("^%d", p->exp);
}
}
else
{
if (p->exp == 0)
printf("%d", p->coef);
else
{
p->coef == -1 ? printf("-x") : printf("%dx", p->coef);
p->exp == 1 ? printf("") : printf("^%d", p->exp);
}
}
}
else if (flag && p->coef != 0)
{
if (p->coef > 0)
{
if (p->exp == 0)
printf("+%d", p->coef);
else
{
p->coef == 1 ? printf("+x") : printf("+%dx", p->coef);
p->exp == 1 ? printf("") : printf("^%d", p->exp);
}
}
else
{
if (p->exp == 0)
printf("%d", p->coef);
else
{
p->coef == -1 ? printf("-x") : printf("%dx", p->coef);
p->exp == 1 ? printf("") : printf("^%d", p->exp);
}
}
}
}
if (!flag)
printf("0");
printf("\n");
}
polynomial *add_polynomial(polynomial *a, polynomial *b)
{
polynomial *head, *p, *tail = NULL;
head = (polynomial *)malloc(sizeof(polynomial));
polynomial *a1 = a->next, *b1 = b->next;
head->next = NULL;
tail = head;
while (a1 && b1)
{
p = (polynomial *)malloc(sizeof(polynomial));
p->next = NULL;
if (a1->exp > b1->exp)
{
p->coef = a1->coef;
p->exp = a1->exp;
tail->next = p;
tail = p;
a1 = a1->next;
}
else if (a1->exp < b1->exp)
{
p->coef = b1->coef;
p->exp = b1->exp;
tail->next = p;
tail = p;
b1 = b1->next;
}
else
{
p->coef = a1->coef + b1->coef;
p->exp = b1->exp;
tail->next = p;
tail = p;
a1 = a1->next;
b1 = b1->next;
}
}
while (a1)
{
p = (polynomial *)malloc(sizeof(polynomial));
p->next = NULL;
p->coef = a1->coef;
p->exp = a1->exp;
tail->next = p;
tail = p;
a1 = a1->next;
}
while (b1)
{
p = (polynomial *)malloc(sizeof(polynomial));
p->next = NULL;
p->coef = b1->coef;
p->exp = b1->exp;
tail->next = p;
tail = p;
b1 = b1->next;
}
return head;
}
polynomial *subtract_polynomial(polynomial *a, polynomial *b)
{
polynomial *head, *p, *tail = NULL;
head = (polynomial *)malloc(sizeof(polynomial));
polynomial *a1 = a->next, *b1 = b->next;
head->next = NULL;
tail = head;
while (a1 && b1)
{
p = (polynomial *)malloc(sizeof(polynomial));
p->next = NULL;
if (a1->exp > b1->exp)
{
p->coef = a1->coef;
p->exp = a1->exp;
tail->next = p;
tail = p;
a1 = a1->next;
}
else if (a1->exp < b1->exp)
{
p->coef = -b1->coef;
p->exp = b1->exp;
tail->next = p;
tail = p;
b1 = b1->next;
}
else
{
p->coef = a1->coef - b1->coef;
p->exp = b1->exp;
tail->next = p;
tail = p;
a1 = a1->next;
b1 = b1->next;
}
}
while (a1)
{
p = (polynomial *)malloc(sizeof(polynomial));
p->next = NULL;
p->coef = a1->coef;
p->exp = a1->exp;
tail->next = p;
tail = p;
a1 = a1->next;
}
while (b1)
{
p = (polynomial *)malloc(sizeof(polynomial));
p->next = NULL;
p->coef = -b1->coef;
p->exp = b1->exp;
tail->next = p;
tail = p;
b1 = b1->next;
}
return head;
}
polynomial *multiply_polynomial(polynomial *a, polynomial *b)
{
polynomial *head, *p1, *tail;
head = (polynomial *)malloc(sizeof(polynomial));
head->next = NULL;
tail = head;
polynomial *p, *q, *t, *cah;
for (p = a->next; p != NULL; p = p->next)
for (q = b->next; q != NULL; q = q->next)
{
int coef = p->coef * q->coef;
int exp = p->exp + q->exp;
for (t = head; t->next != NULL; t = t->next)
{
if (t->next->exp < exp)
{
cah = (polynomial *)malloc(sizeof(polynomial));
cah->coef = coef;
cah->exp = exp;
cah->next = t->next;
t->next = cah;
break;
}
else if (t->next->exp == exp)
{
t->next->coef += coef;
break;
}
}
if (!t->next)
{
cah = (polynomial *)malloc(sizeof(polynomial));
cah->coef = coef;
cah->exp = exp;
t->next = cah;
cah->next = NULL;
}
}
return head;
}
PTA 6-14 用单向链表完成多项式运算(35分)的更多相关文章
- PTA 7-2 畅通工程之局部最小花费问题 (35分)
PTA 7-2 畅通工程之局部最小花费问题 (35分) 某地区经过对城镇交通状况的调查,得到现有城镇间快速道路的统计数据,并提出"畅通工程"的目标:使整个地区任何两个城镇间都可以实 ...
- Linus:利用二级指针删除单向链表
Linus大神在slashdot上回答一些编程爱好者的提问,其中一个人问他什么样的代码是他所喜好的,大婶表述了自己一些观点之后,举了一个指针的例子,解释了什么才是core low-level codi ...
- 【转】Linus:利用二级指针删除单向链表
原文作者:陈皓 原文链接:http://coolshell.cn/articles/8990.html 感谢网友full_of_bull投递此文(注:此文最初发表在这个这里,我对原文后半段修改了许多, ...
- 输入一个单向链表,输出该链表中倒数第K个结点
输入一个单向链表,输出该链表中倒数第K个结点,具体实现如下: #include <iostream> using namespace std; struct LinkNode { publ ...
- [置顶] ※数据结构※→☆线性表结构(list)☆============单向链表结构(list single)(二)
单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始:链表是使用指针进行构造的列表:又称为结点列表,因为链表是由一个个结点组装起来的:其中每个结点都有指 ...
- C#学习单向链表和接口 IList<T>
C#学习单向链表和接口 IList<T> 作者:乌龙哈里 时间:2015-11-04 平台:Window7 64bit,Visual Studio Community 2015 参考: M ...
- c/c++ 线性表之单向链表
c/c++ 线性表之单向链表 线性表之单向链表 不是存放在连续的内存空间,链表中的每个节点的next都指向下一个节点,最后一个节点的下一个节点是NULL. 真实的第一个节点是头节点,头节点不存放数据, ...
- Alan Cox:单向链表中prev指针的妙用
之前发过一篇二级指针操作单向链表的例子,显示了C语言指针的灵活性,这次再探讨一个指针操作链表的例子,而且是一种完全不同的用法. 这个例子是linux-1.2.13网络协议栈里的,关于链表遍历& ...
- JavaScript实现单向链表
JavaScript 本身提供了十分好用的数据类型,以满足大家的日常使用.单靠 Array 和 Object 也的确足够应付日常的绝大部分需求,这也导致了很多前端er对数据结构这一块不是十分的了解. ...
随机推荐
- HDU 2899 Strange fuction [二分]
1.题意:给一个函数F(X)的表达式,求其最值,自变量定义域为0到100 2.分析:写出题面函数的导函数的表达式,二分求导函数的零点,对应的就是极值点 3.代码: # include <iost ...
- Java中的循环结构
1.while循环结构 语法: while(循环条件){ //循环操作 } while循环结构流程图: 举例: int i = 1; while(i <= 100){ System.out.pr ...
- 使用Gson中的JsonElement所遇到的坑
使用Gson中的JsonElement所遇到的坑 原文链接: https://blog.csdn.net/weixin_30326515/article/details/98196013 声明:此博客 ...
- 003 ansible部署ceph集群
介绍:在上一次的deploy部署ceph,虽然出了结果,最后的结果并没有满足最初的目的,现在尝试使用ansible部署一遍,看是否会有问题 一.环境准备 ceph1充当部署节点,ceph2,ceph3 ...
- echarts实现group关系图案例
官网案例:https://www.echartsjs.com/examples/zh/editor.html?c=graph-simple 自己在项目中实现了两个group图: 1.先看实现效果,两个 ...
- 深度兴趣网络DIN-SIEN-DSIN
看看阿里如何在淘宝做推荐,实现"一人千物千面"的用户多样化兴趣推荐,首先总结下DIN.DIEN.DSIN: 传统深度学习在推荐就是稀疏到embedding编码,变成稠密向量,喂给N ...
- iptables 添加80端口规则
iptables -t filter -A INPUT -p tcp -s 10.0.0.0/24 -j DROP 在filter表的input链做规则丢弃10.0.0.0网段的ip包iptables ...
- EXE和DLL调用关系,DLL制作,钩子
制作DLL时,在cpp种引入了头文件,但头文件里的全局变量在cpp种却不能用 参考大佬博客https://blog.csdn.net/speargod/article/details/88854344 ...
- 论Java中的抽象类与接口
目录 抽象类和抽象方法 定义 与普通类的区别以及注意点: 抽象类的作用 接口 定义 示例 注意 作用 最后:接口与抽象类的异同 使用场景 借鉴 抽象类和抽象方法 定义 抽象方法和抽象类都必须被abst ...
- 用来更新服务的bat 脚本
net stop XK.Service echo "已停止服务,开始更新!" set /a t = echo %t% :loop 127.1 >nul set /a t = ...