c语言用单链表输出学号和姓名,急啊!!!求救了 C语言编一个链表,输出姓名和学号就好...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

#include

#include

#include

#include

typedef struct Node

{

int data;

struct Node *next;

}AN;

int data;

AN *CreList(AN *head);

AN *InsList(AN *head,int data);

AN *DelList(AN *head,int data);

void find(int value,AN *head);

void Des(AN *head);

void display(AN *head);

void main()

{

char j='y';int x;AN *head=NULL;

printf("请创建一个链表,以0结束\n");head=CreList(head);

while(j=='y')

{

j=0;

printf("选择操作:\n1.重新创建链表\n2.插入数据\n3.删除数据\n4.查找某个数\n5.输出链表\n6.删除链表\n");

scanf("%d",&x);

switch(x)

{

case 1:

printf("请输入链表,以0结束\n");head=CreList(head);break;

case 2:

printf("请插入一个数字\n");scanf("%d",&data);head=InsList(head,data);break;

case 3:

printf("删除哪个数?\n");scanf("%d",&data);head=DelList(head,data);break;

case 4:

printf("查找那个数?\n");scanf("%d",&data);find(data,head);break;

case 5:

display(head);break;

case 6:

Des(head);break;

default :0;

}

printf("continue?(y or n)\n");

while(j!='y'&&j!='n')

{

j=getch();

}

system("cls");

}

}

AN *CreList(AN *head)

{

AN *p;

AN *p1=NULL;

p=(AN *)malloc(sizeof(AN));

int x;

scanf("%d",&x);

p->data=x;

p->next=NULL;

head=p;p1=p;

while(x!=0)

{

p=(AN*)malloc(sizeof(AN));

scanf("%d",&x);

if(x==0){free(p);p=NULL;break;}

p->data=x;

p->next=NULL;

p1->next=p;

p1=p;

}

return head;

}

void display(AN *head)

{

AN *p=head;

while(p!=NULL)

{

printf("%d\n",p->data);

p=p->next;

}

}

AN *InsList(AN *head,int data)

{

AN *w,*p=head,*p1=head;

if((w=(AN *)malloc(sizeof(AN)))==NULL)

printf("内存空间申请失败\n");

else

{

w->data=data;

w->next=NULL;

if(w->data<=p->data)

{w->next=head;return w;}

else

{

while(w->data>p->data&&p->next!=NULL)

{

p1=p;

p=p->next;

}

if(w->data>p->data)

{

p1=p;

p=p->next;

}

p1->next=w;

w->next=p;

}

}

return head;

}

AN *DelList(AN *head,int data)

{

AN *p=head,*p1=head;

while(p->data!=data)

{

p1=p;

p=p->next;

if(p==NULL)break;

}

if(p==NULL) printf("表中无此数\n ");

else

if(head->data==p->data)

{

head=head->next;

free(p);

}

else

p1->next=p->next;

p=NULL;

free(p);

return head;

}

void find(int value,AN *head)

{

AN *p=head;

int count=0;

while(p->data!=value&&p->next!=NULL)

{

p=p->next;count++;

}

if(p->next==NULL&&p->data!=value)

printf("链表里无此数\n");

else

printf("是第%d个数\n",count+1);

}

void Des(AN *head)

{

AN *p;

while(head->next!=NULL)

{

p=head;

head=head->next;

free(p);

}

free(head);

printf("链表成功删除");

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个关于数据结构的问题。单链表是一种常见的数据结构,它由一系列节点组成,每个节点包含一个数据元素和一个指向下一个节点的指针。对于这个问题,我们可以定义一个结构体来表示学生信息,包括学号姓名和成绩,然后使用指针来连接这些节点,形成一个单链表。具体实现可以参考以下代码: ``` struct student { int id; // 学号 char name[20]; // 姓名 float score; // 成绩 struct student *next; // 指向下一个节点的指针 }; // 创建一个新节点 struct student *create_node(int id, char *name, float score) { struct student *p = (struct student *)malloc(sizeof(struct student)); p->id = id; strcpy(p->name, name); p->score = score; p->next = NULL; return p; } // 在链表尾部插入一个节点 void insert_node(struct student **head, struct student *node) { if (*head == NULL) { *head = node; } else { struct student *p = *head; while (p->next != NULL) { p = p->next; } p->next = node; } } // 遍历链表输出每个节点的信息 void print_list(struct student *head) { struct student *p = head; while (p != NULL) { printf("id: %d, name: %s, score: %.2f\n", p->id, p->name, p->score); p = p->next; } } // 测试代码 int main() { struct student *head = NULL; insert_node(&head, create_node(1, "Tom", 85.5)); insert_node(&head, create_node(2, "Jerry", 90.0)); insert_node(&head, create_node(3, "Alice", 92.5)); print_list(head); return 0; } ``` 这段代码定义了一个包含学生信息的结构体,然后使用指针来连接这些节点,形成一个单链表。我们可以通过调用 create_node 函数来创建一个新节点,然后使用 insert_node 函数将其插入到链表尾部。最后,我们可以使用 print_list 函数遍历链表输出每个节点的信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值