发布网友 发布时间:2022-04-23 06:16
共2个回答
热心网友 时间:2023-10-03 04:40
在这个程序的基础上改下,刚好无聊写了下。关键还是自己去想。#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAX 50
struct person
{
char name[MAX];
int number;
struct person *next;
};struct person * input()
{
struct person *p,*q,*head;
head = NULL;
char temp[MAX];
puts("In put name:");
while(gets(temp)!=NULL && temp[0] != '\0')
{
p = (struct person*)malloc(sizeof(struct person));
if(head == NULL)
head = p;
else
q->next = p;
p->next = NULL;
strcpy(p->name,temp);
puts("number:");
scanf("%d",&p->number);
while(getchar()!='\n')
continue;
puts("The next name:");
q = p; }
return head;
}
void out(struct person *head)
{
struct person *p;
if(head == NULL)
puts("Not name in line");
else
{
p = head;
puts("---------------------");
puts("the person with number:");
while(p)
{
{
printf("name is %s the number is %d\n",p->name,p->number);
p=p->next;
}
}
puts("out end");
}
}
void cleanup(struct person *head)
{
struct person *p;
p=head;
while(p!=NULL)
{
free(p);
p=p->next;
}
}
main()
{
struct person *head;
head = input();
out(head);
cleanup(head);
return 0;
}
热心网友 时间:2023-10-03 04:40
应该再加一个函数比较好、加一个插入元素到链表的函数、创建链表和添加元素是不同的概念、过程也不同、、
热心网友 时间:2023-10-03 04:40
在这个程序的基础上改下,刚好无聊写了下。关键还是自己去想。#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAX 50
struct person
{
char name[MAX];
int number;
struct person *next;
};struct person * input()
{
struct person *p,*q,*head;
head = NULL;
char temp[MAX];
puts("In put name:");
while(gets(temp)!=NULL && temp[0] != '\0')
{
p = (struct person*)malloc(sizeof(struct person));
if(head == NULL)
head = p;
else
q->next = p;
p->next = NULL;
strcpy(p->name,temp);
puts("number:");
scanf("%d",&p->number);
while(getchar()!='\n')
continue;
puts("The next name:");
q = p; }
return head;
}
void out(struct person *head)
{
struct person *p;
if(head == NULL)
puts("Not name in line");
else
{
p = head;
puts("---------------------");
puts("the person with number:");
while(p)
{
{
printf("name is %s the number is %d\n",p->name,p->number);
p=p->next;
}
}
puts("out end");
}
}
void cleanup(struct person *head)
{
struct person *p;
p=head;
while(p!=NULL)
{
free(p);
p=p->next;
}
}
main()
{
struct person *head;
head = input();
out(head);
cleanup(head);
return 0;
}
热心网友 时间:2023-10-03 04:40
应该再加一个函数比较好、加一个插入元素到链表的函数、创建链表和添加元素是不同的概念、过程也不同、、