PTA 02-线性结构2 一元多项式的乘法与加法运算 (20分)
原题地址
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分)的更多相关文章
- PTA数据结构 习题3.6 一元多项式的乘法与加法运算 (20分)
一元多项式的乘法与加法运算 https://pintia.cn/problem-sets/434/problems/5865 设计函数分别求两个一元多项式的乘积与和. 时间限制:200 ms 内存限制 ...
- PAT 02-线性结构2 一元多项式的乘法与加法运算 (20分)
设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...
- 线性结构2 一元多项式的乘法与加法运算 【STL】
02-线性结构2 一元多项式的乘法与加法运算(20 分) 设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和 ...
- 线性结构CT 02-线性结构1 一元多项式的乘法与加法运算
设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...
- 3-04. 一元多项式的乘法与加法运算(20)(ZJU_PAT 结构体)
题目链接:http://pat.zju.edu.cn/contests/ds/3-04 设计函数分别求两个一元多项式的乘积与和. 输入格式说明: 输入分2行.每行分别先给出多项式非零项的个数.再以指数 ...
- 浙江大学PAT上机题解析之3-04. 一元多项式的乘法与加法运算
设计函数分别求两个一元多项式的乘积与和. 输入格式说明: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分 ...
- 一元多项式的乘法与加法运算 【STL-map哈希-map反向迭代器遍历 + 零多项式】
设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...
- 一元多项式的乘法与加法运算(C语言)
输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. 输出格式: 输出分2行,分别以指数递降方 ...
- PAT线性结构_一元多项式求导、按给定步长反转链表、出栈序列存在性判断
02-线性结构1. 一元多项式求导 (25) 设计函数求一元多项式的导数.(注:xn(n为整数)的一阶导数为n*xn-1.) 输入格式:以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过100 ...
随机推荐
- 维骨力Glucosamine的最关键的几点...
1.每日劑量應為多少?長期服用安全嗎? 由於葡萄糖胺(Glucosamine)和軟骨素(Chondroitin)原來就存在於人體,是人體每天會生產製造的必需營養素,因此,一般認為服用此類產品的安全性相 ...
- Unity3d中UnityEngine.Object
UnityEngine.Object继承自system.Object,是Unity所涉及所有物体的基类. Static Functions 静态函数 下面的都是静态函数 Destroy Remov ...
- 小程序java解密
<dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcprov-jdk16< ...
- 全志R58平台的GPIO引脚控制
全志R58平台的GPIO引脚控制 2017/8/18 15:50 版本:V1.0 开发板:SC5806(全志R58平台) SDK:android4.4.4 本文以GPIO引脚PD24为例,在开发板的背 ...
- BeanUtils.copyProperties(productInfo, productInfoVO);
一:spring的工具类方法:BeanUtils.copyProperties(orderMasterDTO, orderMasterDO); 作用:将orderMasterDTO对象中的属性值,赋值 ...
- 最新精品 强势来袭 XP,32/64位Win7,32/64位Win8,32/64位Win10系统【国庆版版】
本系统是10月最新完整版本的Windows10 安装版镜像,Win10正式版,更新了重要补丁,提升应用加载速度,微软和百度今天宣布达成合作,百度成为Win10 Edge浏览器中国默认主页和搜索引擎,系 ...
- Servlet 3.0 新特性详解 (转载)
原文地址:https://www.ibm.com/developerworks/cn/java/j-lo-servlet30/ Servlet 3.0 新特性概述 Servlet 3.0 作为 Jav ...
- SEO 第三章
SEO第三章 本次课目标: 1. 掌握关键词的选取方法 2. 掌握关键词的竞争强度分析 3. 掌握关键词的拓展方法 一.关键词的选取 选择关键词的时候可以根据公司网站的定位,围绕公司的主营产品或 ...
- python笔记_magic变量和函数
前言 先扯一点背景知识 PEP8(Python Enhancement Proposal)是一份python的编码规范,链接:http://www.python.org/dev/peps/pep-00 ...
- 我所理解的MVVM
将UI中的数据适配.交互处理: controller中与UI密切相关的功能: 剥离出来,形成单独的模块: 以增加UI和Controller的灵活性.