链表的c语言实现,链表c语言实现

8f900a89c6347c561fdf2122f13be562.png View Code

#include

#include

#define MAX_SIZE 50

#define MIN_SIZE 32

struct role

{

int number;

char name[MAX_SIZE];

char sex[MIN_SIZE];

char address[MAX_SIZE];

int age;

struct role *next;

};

struct role *creat()

{

struct role *head = NULL;

struct role *p = NULL;

struct role *tail = NULL;

p = (struct role *)malloc(sizeof(struct role));

printf("请输入编号,按0退出

");

printf("编号->");

scanf("%d", &(p->number));

if (0 == p->number)

{

free(p);

return 0;

}

while (0 != p->number)

{

printf("姓名->");

scanf("%s", p->name);

printf("性别->");

scanf("%s", p->sex);

printf("地址->");

scanf("%s", p->address);

printf("年龄->");

scanf("%d", &(p->age));

if (NULL == head)

{

head = p;

tail = p;

}

else

{

tail->next = p;

tail = p;

}

p = (struct role *)malloc(sizeof(struct role));

printf("请输入编号,按0退出

");

printf("编号->");

scanf("%d", &(p->number));

}

tail->next = NULL;

free(p);

return head;

}

void display(struct role *head)

{

struct role *p = NULL;

p = head;

printf("编号 姓名 性别 住址 年龄

");

while (NULL != p)

{

printf("%-16d%-16s%-16s%-16s%-16d",

p->number, p->name, p->sex, p->address, p->age);

p = p->next;

}

}

int main(void)

{

struct role *head = NULL;

head = creat();

display(head);

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值