数据结构课程设计新学生信息管理

#include<stdio.h>
#include<malloc.h>
#include <string.h>
#define NULL 0
struct Student
{
long num;
char name[20];
char sex[4];
int year;
int month;
int day;
char email[20];
long PHONE;
char address[30];
struct Student *next;
};
int n;
struct Student * creat(void)
{
struct Student *head;
struct Student *p1,*p2;
p1=p2=(struct Student * )malloc(sizeof(struct Student));
printf("输入学号:");
scanf("%ld", &p1->num);
printf("输入姓名:");
scanf("%s", p1->name);
printf("输入性别:");
scanf("%s", p1->sex);
printf("输入出生年月日:");
scanf("%d%d%d", &p1->year,&p1->month,&p1->day);
printf("输入email: ");
scanf("%s",p1->email);
printf("输入电话:");
scanf("%ld",&p1->PHONE);
printf("输入家庭住址:");
scanf("%s",p1->address);
head=NULL;
while(p1->num!=0)
{
n=n+1;
if(n==1) head=p1;
else p2->next=p1;
p2=p1;
p1=(struct Student*)malloc(sizeof(struct Student));
printf("输入学号:");
scanf("%ld", &p1->num);
printf("输入姓名:");
scanf("%s", p1->name);
printf("输入性别:");
scanf("%s", p1->sex);
printf("输入出生年月日:");
scanf("%d %d %d", &p1->year,&p1->month,&p1->day);
printf("输入email: ");
scanf("%s",p1->email);
printf("输入电话:");
scanf("%ld",&p1->PHONE);
printf("输入家庭住址:");
scanf("%s",p1->address);
}
p2->next=NULL;
return(head);
}
void print(struct Student *head)
{
struct Student *p;
printf("\n%d个学生的信息为:\n",n);
p=head;
if(head!=NULL)
do
{
printf("学号:%d\n",p->num);
printf("姓名:%s\n",p->name);
printf("性别:%s\n",p->sex);
printf("%d 年%d 月%d 日出生\n",p->year,p->month,p->day);
printf("email:%s\n",p->email);
printf("电话:%ld\n",p->PHONE);
printf("家庭住址:%s\n",p->address);
p=p->next;
}
while(p!=NULL);
}
struct Student * del(struct Student *head,long num)
{
struct Student *p1,*p2;
if(head==NULL)
{ printf("\n 列表为空! \n");
return head;
}
p1=head;
while((num!=p1->num)&&(p1->next!=NULL))
{
p2=p1;
p1=p1->next;
}
if(num==p1->num)
{
if(p1==head) head=p1->next;
else p2->next=p1->next;
printf("已删除学号:%ld\n",num);
n=n-1;
}
else printf("%ld未找到\n",num);
return head;
}
struct Student * insert(struct Student *head,struct Student * stud)
{
struct Student *p0,*p1,*p2;
p1=head;
p0=stud;
if(head==NULL)
{
head=p0;p0->next=NULL;
}
else
{
while((p0->num>p1->num)&&(p1->next!=NULL))
{
p2=p1;
p1=p1->next;
}
if(p0->num<=p1->num)
{
if(head==p1) head=p0;
else p2->next=p0;
p0->next=p1;
}
else
{ p1->next=p0;
p0->next=NULL;}
}
n=n+1;
return head;
}
void se


arch(struct Student *head,long num)
{
struct Student * p = head;
while(p!=NULL)
{
if(p->num==num)
{
printf("学号:%d\n",p->n

Word文档免费下载Word文档免费下载:数据结构课程设计新学生信息管理 (共4页,当前第1页)

你可能喜欢

  • C语言课程设计学生信息管理系统
  • c语言数据结构课程设计
  • c++数据结构课程设计
  • 哈希表设计数据结构课程设计
  • 数据结构课程设计说明书
  • 数据结构课程设计停车场
  • 数据结构课程设计题目
  • 数据结构课程设计排序

数据结构课程设计新学生信息管理相关文档

最新文档

返回顶部