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对数据结构这一块不是十分的了解. ...
随机推荐
- 超简单!pytorch入门教程(五):训练和测试CNN
我们按照超简单!pytorch入门教程(四):准备图片数据集准备好了图片数据以后,就来训练一下识别这10类图片的cnn神经网络吧. 按照超简单!pytorch入门教程(三):构造一个小型CNN构建好一 ...
- scrf 原理及flask-wtf防护
了解什么是scrf? SCRF跨站点请求伪造Cross—Site Request Forgery) 指恶意用户通过个人用户的点击,然而盗用用户的账号信息,并发送邮件.虚拟货币的转账,以及一些重要的事务 ...
- 专业版12.0试用,打开演示账套,提示“列名FPlatver无效”
你好,我代表研发来说明一下这个问题:一.产生的原因:由于KIS产品今年陆续都增加了应用平台,前期平台兼容性还有些问题,如果一台电脑有多个不同版本的平台,就会产生冲突,因此报错.1.可能您的机器装了多个 ...
- 【题解】P4091 [HEOI2016/TJOI2016]求和
[题解]P4091 [HEOI2016/TJOI2016]求和 [P4091 HEOI2016/TJOI2016]求和 可以知道\(i,j\)从\(0\)开始是可以的,因为这个时候等于\(0\).这种 ...
- $loj$10222 佳佳的$Fibonacci$ 矩阵快速幂
正解:矩阵快速幂 解题报告: 我永远喜欢loj! 一看到这个就应该能想到矩阵快速幂? 然后就考虑转移式,发现好像直接想不好想,,,主要的问题在于这个*$i$,就很不好搞$QAQ$ 其实不难想到,$\s ...
- python+selenium+Chrome options参数
python+selenium+Chrome options参数 Chrome Options常用的行为一般有以下几种: 禁止图片和视频的加载:提升网页加载速度. 添加代理:用于翻墙访问某些页面,或者 ...
- 从0开发3D引擎(二):准备预备知识
大家好,本文介绍了开发3D引擎需要的预备知识,给出了相关的资源. 上一篇博文 从0开发3D引擎(一):开篇 了解Web 3D Web 3D的历史 目前Web 3D是基于WebGL这个Web端3D AP ...
- flask 中的 werkzeug Local,LocalStack 和 LocalProxy 技术应用
什么是 Local wsgi 每次请求,会把过程进行抽离无状态话,过程数据存储在本次请求的全局变量中,使用到了Local. Local 作为每次请求的全局命令空间,属于每次请求的私有 LocalSta ...
- 从头学pytorch(十四):lenet
卷积神经网络 在之前的文章里,对28 X 28的图像,我们是通过把它展开为长度为784的一维向量,然后送进全连接层,训练出一个分类模型.这样做主要有两个问题 图像在同一列邻近的像素在这个向量中可能相距 ...
- UCI 人口收入数据分析(python)
一.项目介绍 UCI上有许多免费的数据集可以拿来练习,可以在下面的网站找寻 http://archive.ics.uci.edu/ml/datasets.html 这次我使用的是人口收入调查,里面会有 ...