用C语言编写一个删除单链表中重复的结点的程序,该怎么写??

 我来答
己玛利39
2012-03-22 · 超过29用户采纳过TA的回答
知道答主
回答量:136
采纳率:0%
帮助的人:79.2万
展开全部
简单给你说一下思路:
肯定要遍历几次链表 必须有一个保存位置的指针 (用来从头到尾遍历链表),还要有一个操作指针(拿操作指针和保存位置指针进行比较,看是否是重复的) ,因为在 单链表中不太容易删除当前结点,因此必须有一个记录操作指针前一位置的指针
需要的指针就是这么多,基本过程是保存位置指针 从 头到尾 遍历 ,在循环内部 操作指针 要遍历到尾部 ,看是否有结点的存的内容跟 保存位置指针的一样,如果一样,要删除 (在这过程中会用到操作指针的前一指针,因此在操作指针遍历的时候要记得积累操作指针的前已指针)
rofcto
2012-03-19 · TA获得超过477个赞
知道小有建树答主
回答量:129
采纳率:0%
帮助的人:97.7万
展开全部
如果*p 和 *(p->next)一样
那么 ptemp = p->next
然后p = ptemp-next;
free(ptemp)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式