哪位大虾帮忙给看一下,为什么运行结果会出错

worldnews 2003-06-01 04:07:46
这是一个用来合并一元多项式的C语言程序,语法没错误,但不知道为什么运行结果却不对哪位大虾帮忙给看一下,感激不尽!!!!!


#include <stdio.h>
#include <malloc.h>


typedef struct /*定义链表结构*/
{
float xs;
int zs;
}elemtype;

typedef struct JIED
{elemtype data;
struct JIED *next;
}infm;

infm *ha,*hb,*hc,*la,*lb,*lc,*s;
int m,n;




int initiate(infm **h) /*链表初始化*/
{if((*h=(infm *)malloc(sizeof(infm)))==NULL)return 0;
(*h)->next=NULL;
return 1;
}



int input(infm **h,infm *l,int m) /*输入链表数据*/
{int i;
l=*h;
for(i=1;i<=m;i++)
{if((s=(infm *)malloc(sizeof(infm)))==NULL)return 0;
s->next=NULL;
scanf("%f,%d",&s->data.xs,&s->data.zs);
l->next=s;
l=l->next;
}
return 1;
}



int hebing(infm **ha,infm **hb,infm **hc)
{la=(*ha)->next;
lb=(*hb)->next;
lc=*hc;
while(la&&lb)
{if((s=(infm *)malloc(sizeof(infm)))==NULL)return 0;
s->next=NULL;

if(la->data.zs>lb->data.zs)
{s->data.zs=lb->data.zs;
s->data.xs=lb->data.xs;
lb=lb->next;
}

if(la->data.zs<lb->data.zs)
{s->data.zs=la->data.zs;
s->data.xs=la->data.xs;
la=la->next;
}

if(la->data.zs==lb->data.zs)
{s->data.zs=lb->data.zs;
s->data.xs=lb->data.xs+la->data.xs;
lb=lb->next;
la=la->next;
}

lc->next=s;
lc=lc->next;
}

while(lb)
{if((s=(infm *)malloc(sizeof(infm)))==NULL)return 0;
s->next=NULL;
s->data.zs=lb->data.zs;
s->data.xs=lb->data.xs;
lc->next=s;
lc=lc->next;
lb=lb->next;
}

while(la)
{if((s=(infm *)malloc(sizeof(infm)))==NULL)return 0;
s->next=NULL;
s->data.zs=la->data.zs;
s->data.xs=la->data.xs;
lc->next=s;
lc=lc->next;
la=la->next;
}
return 1;
}


int output(infm **hc,char c)
{int j=0,i; /*计数器*/
s=(*hc)->next;
while(s)
{s=s->next;
j++;
}

printf("合并后的多项式%c(x)=",c);

s=(*hc)->next;
for(i=1;i<j;i++)
{printf("%8.2fxe[%d]+",s->data.xs,s->data.zs);
s=s->next;
}
printf("%8.2fxe[%d]\n",s->data.xs,s->data.zs);
return 1;
}



void main()
{
char a='A',b='B',c='C';

printf("请输入A(x)的项数:\n");
scanf("%d",&m);
printf("请输入B(x)的项数:\n");
scanf("%d",&n);


initiate(&ha);

initiate(&hb);


printf("请输入A(x)的系数和指数(以\",\"间隔):\n");
input(&ha,la,m);

output(&ha,a);

printf("请输入B(x)的系数和指数(以\",\"间隔):\n");
input(&hb,lb,n);
output(&hb,b);


initiate(&hc);

hebing(&ha,&hb,&hc);

output(&hc,c);
}
...全文
77 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
worldnews 2003-06-15
  • 打赏
  • 举报
回复
谢谢各位!!!
rvvd 2003-06-02
  • 打赏
  • 举报
回复
to worldnews
在C中指针是最难使用的,要写出好的代码,首先要去理解别人的写代码的风格和设计思想,我建议你买本软件水平考试的书《系统设计师》(高级程序员)看看,里面所讲的数据结构很经典,那里的编程风格和好,我想你要是读懂高级程序员这本书,上面的问题就自然解决了。
worldnews 2003-06-02
  • 打赏
  • 举报
回复
忘了一个条件
合并前和合并后的多项式都是按指数升幂排列的


多谢各位指教
但问题好象还没解决
hello_wyq 2003-06-01
  • 打赏
  • 举报
回复
int output(infm **hc,char c)
{int j=0,i; /*计数器*/
s=(*hc)->next;
while(s)用while这么算,会不会少了一个呢??
{s=s->next;
j++;
}

printf("合并后的多项式%c(x)=",c);

s=(*hc)->next;
for(i=1;i<j;i++)
{printf("%8.2fxe[%d]+",s->data.xs,s->data.zs);
s=s->next;
}
printf("%8.2fxe[%d]\n",s->data.xs,s->data.zs);
return 1;
}
hello_wyq 2003-06-01
  • 打赏
  • 举报
回复
int hebing(infm **ha,infm **hb,infm **hc)看了一些,但是你没有说明,我就没有好好看
不过有点请注意,la, lb的改变不会影响原来的联表头值的变化,合并以后可能原来的联表指向的头是错误的。
hello_wyq 2003-06-01
  • 打赏
  • 举报
回复
错误1:
int input(infm **h,infm *l,int m) /*输入链表数据*/
{int i;
l=*h;不要了
for(i=1;i<=m;i++)
{if((s=(infm *)malloc(sizeof(infm)))==NULL)return 0;
s->next=NULL; 改成 s->next = *h; //插入到最前面
scanf("%f,%d",&s->data.xs,&s->data.zs);
l->next=s;不要了
l=l->next;不要了
添加一个 *h = s;//更新头指针
}
return 1;
}
shortppsy 2003-06-01
  • 打赏
  • 举报
回复
Ctrl+F10
ewayne 2003-06-01
  • 打赏
  • 举报
回复
最好单步调试!
dragonlw 2003-06-01
  • 打赏
  • 举报
回复
这么大的程序,这么多的指针,而且许多是
**ptr,又有malloc,我看内存使用这儿就要十分的小心了
你仔细检查吧
你想当“李逍遥”式的“大侠”吗? 这里无需计算机基础,无需编程经验,你也不必是计算机专业的在校大学生....只要爱好游戏,怀揣梦想! 有一定自主学习能力,跟着刘老师从“编程小白”修炼为游戏研发“大虾”吧!!!学习好Unity,其先决条件是一定要有稳固、扎实的编程基础!课程 《C# For Unity系列之入门篇》配套学习资料链接:http://pan.baidu.com/s/1gflxreN 密码:sou5;刘老师讲Unity学员群(2) 497429806一、热更新系列(技术含量:中高级):A:《lua热更新技术中级篇》https://edu.csdn.net/course/detail/27087B:《热更新框架设计之Xlua基础视频课程》https://edu.csdn.net/course/detail/27110C:《热更新框架设计之热更流程与热补丁技术》https://edu.csdn.net/course/detail/27118D:《热更新框架设计之客户端热更框架(上)》https://edu.csdn.net/course/detail/27132E:《热更新框架设计之客户端热更框架(中)》https://edu.csdn.net/course/detail/27135F:《热更新框架设计之客户端热更框架(下)》https://edu.csdn.net/course/detail/27136二:框架设计系列(技术含量:中级): A:《游戏UI界面框架设计系列视频课程》https://edu.csdn.net/course/detail/27142B:《Unity客户端框架设计PureMVC篇视频课程(上)》https://edu.csdn.net/course/detail/27172C:《Unity客户端框架设计PureMVC篇视频课程(下)》https://edu.csdn.net/course/detail/27173D:《AssetBundle框架设计_框架篇视频课程》https://edu.csdn.net/course/detail/27169三、Unity脚本从入门到精通(技术含量:初级)A:《C# For Unity系列之入门篇》https://edu.csdn.net/course/detail/4560B:《C# For Unity系列之基础篇》https://edu.csdn.net/course/detail/4595C: 《C# For Unity系列之中级篇》https://edu.csdn.net/course/detail/24422D:《C# For Unity系列之进阶篇》https://edu.csdn.net/course/detail/24465四、虚拟现实(VR)与增强现实(AR):(技术含量:初级)A:《虚拟现实之汽车仿真模拟系统 》https://edu.csdn.net/course/detail/26618五、Unity基础课程系列(技术含量:初级) A:《台球游戏与FlappyBirds—Unity快速入门系列视频课程(第1部)》 https://edu.csdn.net/course/detail/24643B:《太空射击与移动端发布技术-Unity快速入门系列视频课程(第2部)》https://edu.csdn.net/course/detail/24645 C:《Unity ECS(二) 小试牛刀》https://edu.csdn.net/course/detail/27096六、Unity ARPG课程(技术含量:初中级):A:《MMOARPG地下守护神_单机版实战视频课程(上部)》https://edu.csdn.net/course/detail/24965B:《MMOARPG地下守护神_单机版实战视频课程(中部)》https://edu.csdn.net/course/detail/24968C:《MMOARPG地下守护神_单机版实战视频课程(下部)》https://edu.csdn.net/course/detail/24979

69,371

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧