- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
.王博华数据结构实验报告
软件中外132王博华
实验二 链表及其多项式相加
Time Limit: 3000MS
Memory Limit: 65536K
Total Submissions: 1127
Accepted: 471Case Time Limit:1000MS
Description
通过有序对输入多项式的各个项,利用单链表存储该一元多项式,并建立的2个存储一元多项式的单链表,然后完成2个一元多项式的相加,并输出相加后的多项式。
Input
输入数据有多组,对于每组测试数据,第一行一个整数n,表示第一个多项式La的项数;接下来n行,每行表示多项式的一项,包含两个元素,表示系数和指数;接下来一个整数m,表示第二个多项式Lb的项数;接下来m行,每行表示多项式的一项,包含两个元素,表示系数和指数;两个多项式的输入都是按指数从小到大。(n,m=1000)
Output
La与Lb相加之后的多项式。按指数从小到大输出,每行一项,用空格把系数和指数分开。
Sample Input
3
1 2
2 3
3 4
3
4 3
2 5
4 6
Sample Output
1 2
6 3
3 4
2 5
4 6
Source
#includestdio.h
#includestdlib.h
struct jiegou
{ int shu,zhishu;
struct jiegou *next;
} *a,*b,*c;
void shuru()
{ jiegou *p,*q;
int i,j,n,m,c,d;
scanf(%d,n);
p=a=(struct jiegou *)malloc(sizeof(jiegou));
for(i=0;in;i++)
{ q=(struct jiegou *)malloc(sizeof(jiegou));
scanf(%d%d,d,c); q-shu=d; q-zhishu=c; p-next=q; p=q; } p-next=NULL;
scanf(%d,n);
p=b=(struct jiegou *)malloc(sizeof(jiegou));
for(i=0;in;i++) { q=(jiegou *)malloc(sizeof(jiegou));
scanf(%d%d,d,c); q-shu=d; q-zhishu=c; p-next=q; p=q; } p-next=NULL; }
void jifa() { jiegou *p,*q;
int e,d,i;
p=c=(struct jiegou *)malloc(sizeof(jiegou));
a=a-next; b=b-next;
while(a!=NULLb!=NULL)
{ if(a-zhishu==b-zhishu)
{ e=a-shu+b-shu; if(e!=0)
{ q=(jiegou *)malloc(sizeof(jiegou));
p-next=q; p=q; p-shu=e; p-zhishu=a-zhishu;
} b=b-next; a=a-next; } else if(a-zhishub-zhishu)
{ q=(jiegou *)malloc(sizeof(jiegou));
p-next=q; p=q; p-shu=a-shu; p-zhishu=a-zhishu; a=a-next;
}
else { q=(jiegou *)malloc(sizeof(jiegou));
p-next=q; p=q; p-shu=b-shu; p-zhishu=b-zhishu; b=b-next; } }
while(a) { q=(jiegou *)malloc(sizeof(jiegou)); p-next=q; p=q;
p-shu=a-shu; p-zhishu=a-zhishu; a=a-next; }
while(b) { q=(jiegou *)malloc(sizeof(jiegou));
p-next=q; p=q; p-shu=b-shu; p-zhishu=b-zhishu; b=b-next; }
p-next=NULL; } void shuchu() { jiegou *p; p=c-next;
while(p) { printf(%d %d\n,p-shu,p-zhishu); p=p-next; } }
int main () { shuru(); jifa();
shuchu(); }
实验三 括号匹配判断算法
Time Limit: 3000MS
Memory Limit: 65
文档评论(0)