原题地址

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. 【LeetCode 337 & 329. memorization DFS】House Robber III

    /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode ...

  2. webkit滤镜

    -webkit-filter: grayscale(1);/*灰度*/ -webkit-filter: sepia(1);/*褐色*/ -webkit-filter: saturate(1);/*饱和 ...

  3. nginx配置参考

    server { listen 443 ssl; server_name apps.qimeng.fm; #charset koi8-r; #证书 ssl_certificate /usr/local ...

  4. iOS三句话实现文本转语音:AVSpeechSynthesizer

    一.介绍 从iOS5开始,iOS系统已经在siri上集成了语音合成的功能,但是是私有API.但是在iOS7,新增了一个简单的API----AVSpeechSynthesizer来做这件事情. 二.案例 ...

  5. maven编译报错 -source 1.5 中不支持 lambda(或diamond) 表达式,编码 UTF-8 的不可映射字符

    在用maven编译项目是由于项目中用了jdk 1.8, 编译是报错  -source 1.5 中不支持 lambda 表达式. 错误原因: Maven Compiler 插件默认会加 -source ...

  6. 启动hadoop时报root@localhost's password: localhost: Permission denied, please try again.错误。

    背景:在装完hadoop及jdk之后,在执行start-all.sh的时候出现root@localhost's password:localhost:permission denied,please ...

  7. Java GC机制简要总结(Java垃圾回收的基本工作原理)

    第一次编辑 2019-05-07 01:09:39 垃圾回收的对象 程序中的不可用对象(不存活的对象,没有任何引用),或者无用的变量信息等,在程序中长期存在会逐渐占用较多的内存空间,导致没有足够的空间 ...

  8. 实现流水灯以间隔500ms的时间闪烁(系统定时器SysTick实现的精确延时)

    /** ****************************************************************************** * @file main.c * ...

  9. Selenium私房菜系列3 -- Selenium API参考手册【ZZ】

    大家在编写测试案例想查阅Selenium API说明时,可以查阅本文,否则请跳过! (注:这里API版本比较老,新版本的Selenium的API在这里不一定能找到.) Selenium API说明文档 ...

  10. 设置QtreeWidget水平滚动条

    转载请注明出处:http://www.cnblogs.com/dachen408/p/7552603.html //设置treewidget水平滚动条 ui.treeWidget->header ...