原题地址

https://pta.patest.cn/pta/test/15/exam/4/question/710

5-2 一元多项式的乘法与加法运算   (20分)

设计函数分别求两个一元多项式的乘积与和。

输入格式:

输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。

输出格式:

输出分2行,分别以指数递降方式输出乘积多项式以及和多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。零多项式应输出0 0

输入样例:

4 3 4 -5 2  6 1  -2 0
3 5 20 -7 4 3 1

输出样例:

15 24 -25 22 30 21 -10 20 -21 8 35 6 -33 5 14 4 -15 3 18 2 -6 1
5 20 -4 4 -5 2 9 1 -2 0
/*
评测结果
时间 结果 得分 题目 编译器 用时(ms) 内存(MB) 用户
2017-07-08 15:53 答案正确 20 5-2 gcc 3 1
测试点结果
测试点 结果 得分/满分 用时(ms) 内存(MB)
测试点1 答案正确 12/12 3 1
测试点2 答案正确 4/4 2 1
测试点3 答案正确 2/2 2 1
测试点4 答案正确 2/2 1 1 框架
- 读入
- 处理
-- 处理加法
-- 处理乘法
- 输出 结构:结构数组 系数
幂数
当前下标
最大下标 量
存第一行
存第二行
存第一行第二行的和
存当前乘法结果
存之前的结果
*/
#include<stdio.h>
#define MAXLEN 10000
struct item{
int coefficient;
int index;
}; typedef struct multinomial{
struct item data[MAXLEN];
int len;
}MN; MN mulA,mulB,mulSum,mulProduct; void MnCopyFirstToSecond(MN *a,MN *b)
{
int i,j;
b->len=a->len;
for(i=0;i<a->len;i++)
{
b->data[i].coefficient=a->data[i].coefficient;
b->data[i].index=a->data[i].index;
}
}
void CalcPlus( MN mA,MN mB,MN *mSum)
{
int i=0,j=0;
mSum->len=0;
while(i<mA.len && j<mB.len) //两个串都没结束
{
if(mA.data[i].index>mB.data[j].index){
if(mA.data[i].coefficient==0){//提防0系数
i++;
continue;
}
mSum->data[mSum->len].coefficient=mA.data[i].coefficient;
mSum->data[mSum->len].index=mA.data[i].index;
mSum->len++;
i++;
}
else if(mB.data[j].index>mA.data[i].index){
if(mB.data[j].coefficient==0){//提防0系数
j++;
continue;
}
mSum->data[mSum->len].coefficient=mB.data[j].coefficient;
mSum->data[mSum->len].index=mB.data[j].index;
mSum->len++;
j++;
}
else if(mA.data[i].index==mB.data[j].index){
if(mA.data[i].coefficient+mB.data[j].coefficient==0){//考虑相加得0的情况
i++;
j++;
continue;
}
mSum->data[mSum->len].coefficient=mA.data[i].coefficient+mB.data[j].coefficient;
mSum->data[mSum->len].index=mA.data[i].index;
mSum->len++;
i++;
j++;
}
} while(i<mA.len){//B结束A没结束
if(mA.data[i].coefficient==0)
{
i++;
continue;
}
mSum->data[mSum->len].coefficient=mA.data[i].coefficient;
mSum->data[mSum->len].index=mA.data[i].index;
mSum->len++;
i++;
} while(j<mB.len){//A结束B没结束
if(mB.data[j].coefficient==0){
j++;
continue;
}
mSum->data[mSum->len].coefficient=mB.data[j].coefficient;
mSum->data[mSum->len].index=mB.data[j].index;
mSum->len++;
j++;
} } void CalcMultiply(MN a,MN b,MN *res)
{
MN currentResult,tempSum;
currentResult.len=0;
tempSum.len=0;
int i=0,j=0;
while(i<a.len){//多项式逐项相乘
while(j<b.len){
currentResult.data[currentResult.len].coefficient=a.data[i].coefficient*b.data[j].coefficient;
currentResult.data[currentResult.len].index=a.data[i].index+b.data[j].index;
currentResult.len++;
j++;
}
CalcPlus(currentResult,tempSum,res);
MnCopyFirstToSecond(res,&tempSum);//CalcPlus()函数中第二个参数与第三个不能相同,故把最近一次累加的结果复制到tempSum中去。
currentResult.len=0;
i++;
j=0; } } void GetInput()
{
int i; scanf("%d",&i);
mulA.len=i;
for(i=0;i<mulA.len;i++)
scanf("%d %d",&mulA.data[i].coefficient,&mulA.data[i].index); scanf("%d",&i);
mulB.len=i;
for(i=0;i<mulB.len;i++)
scanf("%d %d",&mulB.data[i].coefficient,&mulB.data[i].index);
} void PrintResult(MN m)
{
if(m.len==0)
{
printf("0 0");
return;
}
int i;
for (i=0;i<m.len;i++)
{
printf("%d %d",m.data[i].coefficient,m.data[i].index);
if(i!=m.len-1)
putchar(' '); }
} int main()
{
GetInput();
CalcMultiply(mulA,mulB,&mulProduct);
PrintResult(mulProduct);
putchar('\n');
CalcPlus(mulA,mulB,&mulSum);
PrintResult(mulSum);
}

  

PTA 02-线性结构2 一元多项式的乘法与加法运算 (20分)的更多相关文章

  1. PTA数据结构 习题3.6 一元多项式的乘法与加法运算 (20分)

    一元多项式的乘法与加法运算 https://pintia.cn/problem-sets/434/problems/5865 设计函数分别求两个一元多项式的乘积与和. 时间限制:200 ms 内存限制 ...

  2. PAT 02-线性结构2 一元多项式的乘法与加法运算 (20分)

    设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...

  3. 线性结构2 一元多项式的乘法与加法运算 【STL】

    02-线性结构2 一元多项式的乘法与加法运算(20 分) 设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和 ...

  4. 线性结构CT 02-线性结构1 一元多项式的乘法与加法运算

    设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...

  5. 3-04. 一元多项式的乘法与加法运算(20)(ZJU_PAT 结构体)

    题目链接:http://pat.zju.edu.cn/contests/ds/3-04 设计函数分别求两个一元多项式的乘积与和. 输入格式说明: 输入分2行.每行分别先给出多项式非零项的个数.再以指数 ...

  6. 浙江大学PAT上机题解析之3-04. 一元多项式的乘法与加法运算

    设计函数分别求两个一元多项式的乘积与和. 输入格式说明: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分 ...

  7. 一元多项式的乘法与加法运算 【STL-map哈希-map反向迭代器遍历 + 零多项式】

    设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...

  8. 一元多项式的乘法与加法运算(C语言)

    输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. 输出格式: 输出分2行,分别以指数递降方 ...

  9. PAT线性结构_一元多项式求导、按给定步长反转链表、出栈序列存在性判断

    02-线性结构1. 一元多项式求导 (25) 设计函数求一元多项式的导数.(注:xn(n为整数)的一阶导数为n*xn-1.) 输入格式:以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过100 ...

随机推荐

  1. ML——决策树模型

    决策树模型 优点:高效简单.易于理解,可以处理不相关特征. 缺点:容易过拟合,训练集在特征上是完备的 决策树过程:特征选择.划分数据集.构建决策树.决策树剪枝 决策树选择最优的划分特征,将数据集按照最 ...

  2. [转]Android TCP长连接 心跳机制及实现

    背景知识 智能手机上的长连接心跳和在Internet上的长连接心跳有什么不同 Android系统的推送和iOS的推送有什么区别 几种推送的实现方式 协议 1XMPP简介 2 MQTT简介 3移动端消息 ...

  3. css3 blur模糊解决ie6-ie9兼容

    css3 blur模糊是css3的新特性,但是不兼容ie6-ie9,以下代码可以解决此问题: filter: progid:DXImageTransform.Microsoft.Blur(Pixel ...

  4. BottomNavigationBar底部导航条用法

    先来张效果图 接下来是实现过程 1.加入依赖 compile 'com.ashokvarma.android:bottom-navigation-bar:1.3.0' 2.xml布局 fragment ...

  5. 不能说的hidden

    不能说的hidden 时光跑跑...路在脚下...晨光依在...----Vashon 1.所谓"时尚",本质上就是自己看不见自己的样子.好比我们在地球上,却感觉不到地球在动. 2. ...

  6. codevs 6116 区间素数

     时间限制: 8 s  空间限制: 256000 KB  题目等级 : 白银 Silver 题解       题目描述 Description 小明喜欢研究素数,他想统计两个自然数之间的素数个数,现在 ...

  7. APP设计细节总结-摘录

    视觉表现型问题 1. 统一的图标设计风格 2. 图标大小的视觉平衡(根据图标的体量对其大小做出相应的调整) 3. 优化你的分割线(通常我们会选择浅色而否定深色) 4. 合理的运用投影的颜色与透明度 5 ...

  8. poptip 外面 放 input 使用 iview vue

    外层套的是 <FormItem prop="name" label="姓名:"> <Input v-model="tFill.nam ...

  9. Modal 下面的 v-model 就是显示不显示 true 或 false

    Modal 下面的 v-model 就是显示不显示 true 或 false

  10. ORA-03113: end-of-file on & ORA-07445

    --------------ORA-03113: end-of-file on-------------- SQL> show parameter background_dump; NAME T ...