第7周编程练习
依照学术诚信条款,我保证此作业是本人独立完成的。
温馨提示:
1.本次作业属于Online Judge题目,提交后由系统即时判分。
2.学生可以在作业截止时间之前不限次数提交答案,系统将取其中的最高分作为最终成绩。
1
多项式加法(5分)
题目内容:
一个多项式可以表达为x的各次幂与系数乘积的和,比如:
2x6+3x5+12x3+6x+20
现在,你的程序要读入两个多项式,然后输出这两个多项式的和,也就是把对应的幂上的系数相加然后输出。
程序要处理的幂最大为100。
输入格式:
总共要输入两个多项式,每个多项式的输入格式如下:
每行输入两个数字,第一个表示幂次,第二个表示该幂次的系数,所有的系数都是整数。第一行一定是最高幂,最后一行一定是0次幂。
注意第一行和最后一行之间不一定按照幂次降低顺序排列;如果某个幂次的系数为0,就不出现在输入数据中了;0次幂的系数为0时还是会出现在输入数据中。
输出格式:
从最高幂开始依次降到0幂,如:
2x6+3x5+12x3-6x+20
注意其中的x是小写字母x,而且所有的符号之间都没有空格,如果某个幂的系数为0则不需要有那项。
输入样例:
6 2
5 3
3 12
1 6
0 20
6 2
5 3
2 12
1 6
0 20
输出样例:
4x6+6x5+12x3+12x2+12x+40
时间限制:500ms内存限制:32000kb
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 | // // main.c // c yuyan // // Created by anzhongyin on 2016/11/29. // Copyright © 2016年 anzhongyin. All rights reserved. // #include <stdio.h> //#include <math.h> int main( int argc, const char * argv[]) { // insert code here... // TODO Auto-generated method stub int a,b; int number[101]={0}; for ( int i=0;i<2;i++) { do { scanf ( "%d %d" ,&a,&b); number[a]+=b; } while (a); } int c=1; for ( int i=101-1;i>=2;i--) { if (c) { if (number[i]==1||number[i]==-1) { printf ( "x%d" ,i); c=0; } else if (number[i]!=0) { printf ( "%dx%d" ,number[i],i); c=0; } } else { if (number[i]==1) { printf ( "+x%d" ,i); } else if (number[i]==-1) { printf ( "x%d" ,i); } else if (number[i]>0) { printf ( "+%dx%d" ,number[i],i); } else if (number[i]<0) { printf ( "%dx%d" ,number[i],i); } } } if (c) { if (number[1]==1||number[1]==-1) { printf ( "x" ); c=0; } else if (number[1]!=0) { printf ( "%dx" ,number[1]); c=0; } if (number[0]!=0) { printf ( "%d" ,number[0]); c=0; } } else { if (number[1]==1) { printf ( "+x" ); } else if (number[1]==-1) { printf ( "x" ); } else if (number[1]>0) { printf ( "+%dx" ,number[1]); } else if (number[1]<0) { printf ( "%dx" ,number[1]); } if (number[0]>0) { printf ( "+%d" ,number[0]); } else if (number[0]<0) { printf ( "%d" ,number[0]); } } if (c){ printf ( "0" ); } printf ( "\n" ); return 0; } |
独学而无友,则孤陋而寡闻。
分类:
C
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix