原题地址

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. 怎么查看这个历史最大连接session数

    select * from dba_high_water_mark_statistics;

  2. MySQL GTID复制

    什么是GTID 什么是GTID呢, 简而言之,就是全局事务ID(global transaction identifier ),最初由google实现,官方MySQL在5.6才加入该功能.GTID是事 ...

  3. 域名IP主动验证(一)

    功能:主动验证给定的域名.IP对是否真正的关联 思路: 1.一开始通过修改hosts文件,把待验证的域名.IP对添加到文件里,然后用wget尝试访问,再恢复hosts文件重新验证下一对 2.后来了解到 ...

  4. 动手实现 Redux(三):纯函数(Pure Function)简介

    我们接下来会继续优化我们的 createStore 的模式,让它使我们的应用程序获得更好的性能. 但在开始之前,我们先用一节的课程来介绍一下一个函数式编程里面非常重要的概念 —— 纯函数(Pure F ...

  5. gp服务输出的结果文件输出到绝对路径

    gp服务跟本地用arcmap执行gp有个不同,就是输出的文件一般只能输出到arcgis server默认的output目录里面(arcgis server有此限制,无论怎么配还是写到output目录里 ...

  6. 清理xcode缓存

    code版本:8.3.3 iOS版本:10.3.2 移除 Xcode 运行安装 APP 产生的缓存文件(DerivedData) 只要重新运行Xcode就一定会重新生成,而且会随着运行程序的增多,占用 ...

  7. Android学习笔记(十六) ContentProvider

    1.相关概念 ContentProvider:不同应用程序之间进行数据交换的标准API:程序“暴露”数据的方法. ContentResolver:一个程序访问另一个程序被“暴露”的数据的方法. Uri ...

  8. Selenium私房菜系列2 -- XPath的使用【ZZ】

    在编写Selenium案例时,少不免是要用到XPath的,现在外面关于XPath使用的参考资料很多,下面我直接转一篇关于XPath使用的文档.如果对XPath不熟悉请参考下文,你不需要去百度/Goog ...

  9. SqlServer2005使用top 100 PERCENT 无法排序的问题

    由于公司提供的分页控件需要我使用top子句,而且有必要将查询到的记录全部取出,确发现不能排序,sql语句如下: SELECT TOP 15 * FROM( SELECT TOP (100) PERCE ...

  10. Java并发编程之原子操作类

    什么是原子操作类当更新一个变量的时候,多出现数据争用的时候可能出现所意想不到的情况.这时的一般策略是使用synchronized解决,因为synchronized能够保证多个线程不会同时更新该变量.然 ...