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对数据结构这一块不是十分的了解. ...
随机推荐
- 解决Win10电脑右下角的“激活windows转到电脑设置”的水印的方法
Win10正式版的用户反馈新系统在使用一段时候后,自己电脑桌面右下角就突然出现了“激活windows10转到设置以激活windows”的水印字样.这是怎么回事呢?下面,我就向大家分享win10电脑右下 ...
- .data()与.detach()的区别
.data()和.detach()都可以获取Variable内部的Tensor,但.detach()更加安全 https://zhuanlan.zhihu.com/p/38475183
- while Ture怎么退出全部
while True: #这是一个死循环 如果想要quit出去只能一层一层的退出 比如如果在第三层输入quit会回到第二层 那么有什么方法能够在第三层就退出全部? print("level1 ...
- 用WPF实现大数据分析,超炫的效果,还带地图
开头语 经过一段时间研究,终于实现CS和BS相同效果的大数据展示平台了.首先来看看实现的效果,超炫的效果,客户特别喜欢,个人也非常满意,分享给各位,同大家一起交流学习. 大数据展示平台 从上图可以看出 ...
- CodeForces 796D
不能一个一个bfs,要一起bfs #include<iostream> #include<vector> #include<cstdio> #include< ...
- 020 ceph作openstack的后端存储
一.使用ceph做glance后端 1.1 创建用于存储镜像的池 [root@serverc ~]# ceph osd pool create images 128 128 pool 'images ...
- 07Shell数组
Shell 数组变量 普通数组:只能使用整数作为数组索引 关联数组:可以使用字符串作为数组索引 普通数组 定义数组 方法1: 一次赋一个值 数组名[索引]=变量值 示例 # array1[0]=pea ...
- 用TensorFlow做图像识别(python)
一.TensorFlow简介 TensorFlow是由谷歌开发的一套机器学习的工具,使用方法很简单,只需要输入训练数据位置,设定参数和优化方法等,TensorFlow就可以将优化结果显示出来,节省了很 ...
- 对接百度地图API 实现地址转经纬度
<?php class BaiduLBS { public static $_ak = '你的KEY值'; # Util::request 是我封装的一个请求URL类,自己可以写一个 可以提交 ...
- java小项目之:扫雷,这游戏没有你想的那么简单!
扫雷 我之前分享的小项目和小游戏,电影购票.坦克大战.捕鱼达人.贪吃蛇等,虽然已经是耳熟能详人尽皆知的项目和游戏,但是保不齐真的有人没接触过. 今天分享的这个项目,我不相信没人接触过(仅限80后-00 ...