一个小小的问题请教高手

renbin5566 2010-04-23 11:53:55
C语言数据结构中链表的删除怎么不能正常删除啊
# include <stdio.h>
# include <malloc.h>
typedef struct Lnode{
int data;
struct Lnode *next;
}Lnode,*Linklist;
Linklist Creat()
{
Linklist head;
head=(Linklist)malloc(sizeof(Lnode));
if(!head){
printf("create fail\n");
return 0;
}
head->data=NULL;
head->next=head;
return head;
}
int Listlength(Linklist head){//求链表的长度
int i=0;
Linklist p;
p=head;
while(p->next!=head){
i++;
p=p->next;
}
return i;
}
void Insertelem(Linklist head,int i,int elem){//插入元素
Linklist p,q;
p=(Linklist)malloc(sizeof(Lnode));
p->data=elem;
q=head;
int pos;
int len=Listlength(head);
if(i<1||i>len+1){
printf("sorry you input error\n");
return ;
}
if(i=len+1){
for(pos=1;pos<i;pos++)
q=q->next;
p->next=q->next;
q->next=p;
}
else{
for(pos=0;pos<i;pos++)
q=q->next;
p->next=q->next;
q->next=p;
}
}
void delelem(Linklist head,int i,int &elem){//删除一个元素
Linklist p,q;
p=head;
if(i<1||i>Listlength(head)){
printf("you put the number is error\n");
return ;
}
int pos;
for(pos=1;pos<i;pos++)
p=p->next;
q=p->next;
p=q->next;
elem=q->data;
}


void Printlist(Linklist head)//输出元素
{
Linklist p;
p=head;
if(p->next==head){
printf("this is a empty list\n");
return ;
}
p=p->next;
while(p->next!=head){
printf("%3d",p->data);
p=p->next;
}
printf("%3d",p->data);
}
void Freelist(Linklist head){
free(head);
}
void main()
{
int i,elem;
Linklist head;
head=Creat();
for(i=1;i<10;i++)
Insertelem(head,i,i*i);
Printlist(head);
printf("\n");
delelem(head,4,elem);
printf("\n");
printf("%d",elem);
printf("\n");
Printlist(head);
free(head);
}


...全文
117 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
elegant87 2010-04-24
  • 打赏
  • 举报
回复

void delelem(Linklist head,int i,int &elem)
{//删除一个元素
Linklist p,q;
p=head;
if(i<1||i>Listlength(head))
{
printf("you put the number is error\n");
return ;
}
int pos;
for(pos=1;pos<i;pos++)
p=p->next;
q=p->next;
p->next=q->next;//此处改下就行了
elem=q->data;
}
elegant87 2010-04-24
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 renbin5566 的回复:]

谢谢。可是我那样的值传递同样可以改变主函数的elem的值的。我试过了,你可以尝试一下,貌似我看的书上都是我i这种方式进行值传递的
[/Quote]
C语言是没有引用&的,可以用指针代替。C++有引用&,你可以在C++编译器下编译这个程序!
renbin5566 2010-04-24
  • 打赏
  • 举报
回复
谢谢。可是我那样的值传递同样可以改变主函数的elem的值的。我试过了,你可以尝试一下,貌似我看的书上都是我i这种方式进行值传递的
lmm_tx 2010-04-24
  • 打赏
  • 举报
回复
1.你的编码风格让人不太愿意看你写的代码。
2.我看了你的delete函数,有很大的问题。此函数应该这样定义
void delelem(Linklist head,int i,int *elem){//删除一个元素
下面for循环应该这样写。
for(pos = 1; pos < i - 1; pos++) //找到要删除的节点
{
p = p->next;
q = p->next;
}
*elem = q->data;
p->next = q->next; //重新链接
free(q); //释放q

main函数里调用也改成:
delelem(head,4,&elem);
值传递是改变不了main函数中的elem的,必须采用传地址。
内容概要:本文提出了一种基于神经网络的数据驱动迭代学习控制(ILC)算法,专门用于解决具有未知动态模型和重复任务特征的非线性单输入单输出(SISO)离散时间系统在无人车路径跟踪中的应用问题,并通过Matlab代码实现了算法的仿真验证。该方法充分利用神经网络强大的非线性逼近能力和自适应学习特性,结合迭代学习控制在周期性任务中逐步优化控制输入的优势,即使在缺乏精确系统数学模型的前提下,也能有效提升无人车在复杂环境下的路径跟踪精度与系统稳定性。算法的核心在于通过多次运行过程中不断修正控制律,实现对期望轨迹的渐近跟踪。; 适合人群:具备一定现代控制理论基础知识、熟悉迭代学习控制基本概念,并拥有Matlab编程与仿真实践经验的研究生、科研人员及自动化、机器人领域的相关工程师。; 使用场景及目标:① 解决无人车在模型未知或难以精确建模的复杂动态环境中的高精度路径跟踪控制问题;② 为一类具有重复运行特性的非线性系统提供一种不依赖精确模型的先进控制策略;③ 推动数据驱动与人工智能方法在自动化控制领域的工程应用与学术研究发展。; 阅读建议:读者应重点理解神经网络在控制律中的设计与集成方式、迭代学习机制的具体实现流程,以及两者融合的创新点。务必结合所提供的Matlab代码进行详细的阅读、调试与仿真分析,通过改变参数和工况来观察控制效果,以深化对算法内在机理和性能特点的掌握。
内容概要:本文档是一份面向参与大学生创新创业训练计划(大创项目)的在校学生的系统性指导资源,全面覆盖国家级与省级项目的申报、执行、中期检查、结题全流程。内容包括大创项目的政策解读、分类与级别说明、申报流程与时间节点、评审标准解析,并提供创新训练、创业训练、创业实践三类项目的申报书撰写指南与范文。文档重点围绕物联网、数据分析、Web应用三大技术方向,提供可运行的完整项目实现案例,如基于ESP32的智慧农场系统、基于Python与Tableau的公交数据可视化平台、基于Spring Boot的校园协作平台,涵盖技术架构、代码实现、系统部署等细节。此外,还包括答辩PPT制作技巧、中期检查与结题报告的撰写模板,以及各类工具与学习资源推荐,助力学生从项目构思到成果落地的全过程。; 适合人群:参与大创项目的在校本科生,尤其是计算机、数据科学、物联网等相关专业,具备一定编程基础和科研兴趣的学生。; 使用场景及目标:①指导学生高效撰写符合评审要求的申报书、答辩材料、中期报告与结题报告;②提供三大主流技术方向的完整项目范例,帮助学生快速搭建原型系统,提升技术实践能力;③辅助团队进行项目规划、进度管理与成果总结,确保项目顺利立项与结题。; 阅读建议:建议根据项目所处阶段选择性阅读对应章节,申报阶段重点学习第1-4章,执行阶段参考第5-9章的技术实现案例,结题阶段使用第6章模板。应结合自身项目特点灵活应用范文与代码,避免照搬,注重原创性与可行性,并积极与指导教师沟通完善方案。

70,038

社区成员

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

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