#include <stdio.h>
#define NUll 0
#include <stdlib.h>
struct stu
{
char name[6];
int xuehao;
int grade;
struct stu *next;
};
typedef struct stu STU;
main()
{
STU *p,*p_start,*p2,*p_print,*p_charu,*p_charu2;
int i,xuehao;
//输入
for (i=0;i<3;i++)
{
p=(STU *)malloc(sizeof(STU));
printf("请输入学生姓名:\n");
scanf("%s",&p->name);
printf("请输入学生的学号:\n");
scanf("%d",&p->xuehao);
printf("请输入学生的成绩:\n");
scanf("%d",&p->grade);
if (i==0)
p2=p_start=p;
else
{
p2->next=p;
p2=p;
if (i==2)
p->next=NULL;
}
}
// printf("%d",p_start->next->next->next);
// printf("%d",p_start->next->next->xuehao);
//链表的插入
p_charu=p_start;
printf("请输入要删除的学号\n");
scanf("%d",&xuehao);
while (1)
{
p_charu2=p_charu->next;
if (p_charu->next->xuehao==xuehao)
{
// if (p_charu->next->next==NULL)
// p_charu->next=NULL;
else
p_charu->next=p_charu->next->next;
free(p_charu2);
break;
}
if (p_charu->xuehao==xuehao)
{
p_start=p_charu->next;
free(p_charu);
break;
}
p_charu=p->next;
}
//输出
p_print=p_start;
/*
for (i=0;i<2;i++)
{
printf("学生姓名为:%s\n",p_print->name);
printf("学生的学号为:%d\n",p_print->xuehao);
printf("学生的分数为:%d\n",p_print->grade);
if (p_print->next!=NULL)
p_print=p_print->next;
}
*/
}
这是一个删除结点并输出的程序,
加注释的输出部分没有问题,关键应该在删除结点的循环那里,但是找不见错误啊,
错误为:当删除最后一个链表也就是3时程序发生错误,停止运行。
求解
include define NUll 0include
struct stu
{
char name[6];
int xuehao;
int grade;
struct stu *next;
};
typedef struct stu STU;
main()
{
STU p,p_start,p2,p_print,p_charu,p_charu2;
int i,xuehao;
//输入
for (i=0;i<3;i++)
{
p=(STU *)malloc(sizeof(STU));
printf("请输入学生姓名:n");
scanf("%s",p->name);
printf("请输入学生的学号:n");
scanf("%d",&p->xuehao);
printf("请输入学生的成绩:n");
scanf("%d",&p->grade);
if (i==0)
{
p2=p_start=p;
}
else
{
p2->next=p;
p2=p;
if (i==2)
p->next=NULL;
}
}
// printf("%d",p_start->next->next->next);
// printf("%d",p_start->next->next->xuehao);
//链表的插入
p_charu=p_start;
printf("请输入要删除的学号n");
scanf("%d",&xuehao);
while (1)
{
p_charu2=p_charu->next;
if (p_charu->next->xuehao==xuehao)
{
// if (p_charu->next->next==NULL)
// p_charu->next=NULL;
}
else
{
p_charu->next=p_charu->next->next;
free(p_charu2);
break;
}
if (p_charu->xuehao==xuehao)
{
p_start=p_charu->next;
free(p_charu);
break;
}
p_charu=p->next;
}
p_print=p_start;
}
代码格式好,花括号都缺少了
struct stu
{
char name[6];
int xuehao;
int grade;
struct stu *next;
};
typedef struct stu STU;
main()
{
STU p,p_start,p2,p_print,p_charu,p_charu2;
int i,xuehao;
//输入
for (i=0;i<3;i++)
{
p=(STU *)malloc(sizeof(STU));
printf("请输入学生姓名:n");
scanf("%s",p->name);
printf("请输入学生的学号:n");
scanf("%d",&p->xuehao);
printf("请输入学生的成绩:n");
scanf("%d",&p->grade);
if (i==0)
{
p2=p_start=p;
}
else
{
p2->next=p;
p2=p;
if (i==2)
p->next=NULL;
}
}
// printf("%d",p_start->next->next->next);
// printf("%d",p_start->next->next->xuehao);
//链表的插入
p_charu=p_start;
printf("请输入要删除的学号n");
scanf("%d",&xuehao);
while (1)
{
p_charu2=p_charu->next;
if (p_charu->next->xuehao==xuehao)
{
// if (p_charu->next->next==NULL)
// p_charu->next=NULL;
}
else
{
p_charu->next=p_charu->next->next;
free(p_charu2);
break;
}
if (p_charu->xuehao==xuehao)
{
p_start=p_charu->next;
free(p_charu);
break;
}
p_charu=p->next;
}
p_print=p_start;
}
代码格式好,花括号都缺少了
include define NUll 0include
struct stu
{
char name[6];
int xuehao;
int grade;
struct stu *next;
};
typedef struct stu STU;
main()
{
STU p,p_start,p2,p_print,p_charu,p_charu2;
int i,xuehao;
//输入
for (i=0;i<3;i++)
{
p=(STU *)malloc(sizeof(STU));
printf("请输入学生姓名:n");
scanf("%s",p->name);
printf("请输入学生的学号:n");
scanf("%d",&p->xuehao);
printf("请输入学生的成绩:n");
scanf("%d",&p->grade);
if (i==0)
{
p2=p_start=p;
}
else
{
p2->next=p;
p2=p;
if (i==2)
p->next=NULL;
}
}
// printf("%d",p_start->next->next->next);
// printf("%d",p_start->next->next->xuehao);
//链表的插入
p_charu=p_start;
printf("请输入要删除的学号n");
scanf("%d",&xuehao);
while (1)
{
p_charu2=p_charu->next;
if (p_charu->next->xuehao==xuehao)
{
// if (p_charu->next->next==NULL)
// p_charu->next=NULL;
}
else
{
p_charu->next=p_charu->next->next;
free(p_charu2);
break;
}
if (p_charu->xuehao==xuehao)
{
p_start=p_charu->next;
free(p_charu);
break;
}
p_charu=p->next;
}
p_print=p_start;
}
代码格式好,花括号都缺少了
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。