实验内容及要求
实验内容:
1.完成线性表链式存储结构的若干典型算法(典型算法可自选)。
学生表维护(用链式存储结构)
(1)建立学生表(前插法、后插法)
(2)输出学生表
(3)添加新同学,使之成为第i号
(4)删除第i号学生
(5)输出学生表的长度
(6)删除指定年龄的学生信息
struct Student {
string id;//学号
string name;//学生姓名
int age;//年龄
}Stu;
2.有一个单链表的第一个结点指针为head,编写一个函数将该单链表逆置,即最后一个结点变成第一个结点,原来倒数第二个结点变成第二个结点。在逆置中不能建立新的单链表。
实验要求:
1.键盘输入数据;
2.屏幕输出运行结果。
3.要求记录实验源代码及运行结果。
4.运行环境:CodeBlocks/Dev C++/VC6.0等C编译环境
参考:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<windows.h>
struct stu //第一部分:声明结构体类型struct stu
{
char name[100];//姓名为字符串型
int xh;//学号为整形
int grade;//年级
char cel[15];//手机
char tel[50];//电话
char mail[50];//邮件
char add[100];//地址为字符串型
char post[15];//邮编
struct stu *next;//用指针处理链表,next是指针变量,指向结构体变量
};
struct stu *charu(struct stu *head,struct stu *q)//第二部分:插入函数(插入新结点)
{
struct stu *p;
for(p=head;p->next!=NULL;p=p->next);//for(使p也指向head;当p为空文件时 ;p指向下一个结点)
p->next=q;
q->next=NULL;
return head;
}
void search(struct stu *head) //第三部分:查找结点并输出
{
struct stu *p;
int a;//要查找学生的学号
if(head->next==NULL)//头文件为空时打印出的结果为"通讯录为空"
printf("**********************************通讯录为空!!!*********************************\n\n\n");
else//头文件不为空时,开始查询学生的信息
{
printf("\t输入要查询学生学号:");
scanf("%d",&a);
for(p=head->next;p->next!=NULL;p=p->next)//for(使p也指向head;当p为空文件时 ;p指向下一个结点)
{
if(p->xh==a) //如果输入的学号和某个相同,输出以下的东西。
{
printf(" 要查找的学生信息为:\n");
printf(" ★姓名:");puts(p->name);
printf("\t学号: ");printf("%d",p->xh);
printf("\t年级:");printf("%d\n",p->grade);
printf("\t手机:");puts(p->cel);
printf("\t电话:");puts(p->tel);
printf("\t邮箱:");puts(p->mail);
printf("\t地址");puts(p->add);
printf("\t邮编:");puts(p->post);
printf("\t查找成功!!!");
printf("\n\n\n");
break;
}
}
if(p->xh==a)
{
printf(" 要查找的学生信息为:\n");
printf(" ★姓名:");puts(p->name);
printf("\t年级:");printf("%d\n",p->grade);
printf("\t手机:");puts(p->cel);
printf("\t电话:");puts(p->tel);
printf("\t邮箱:");puts(p->mail);
printf("\t地址");puts(p->add);
printf("\t邮编:");puts(p->post);
printf("\t查找成功!!!");
printf("\n\n\n");
}
else printf("no people have found!!!\n");//如果不符合,就输出没有找到
}
}
struct stu *del(struct stu *head) //第四部分:删除结点
{
struct stu *p,*q;
int a;//要删除学生的学号
if(head->next==NULL)// 头文件为空时,输出通讯录为空
printf("**********************************通讯录为空!!!*********************************\n\n\n");
else
{
printf("\t输入要删除学生学号:");
scanf("%d",&a);
for(p=head,q=p->next;q->xh!=a&&q->next!=NULL;)
{
p=p->next;
q=p->next;
}
if(q->xh==a)
{
p->next=q->next;
free(q);//释放q,也就是删除q,在这里就是删除q(学号为a)
printf("删除成功!!!\n");
}
else printf("no people have found!!!");//如果不符合,就输出没有找到
}
return head;//返回头文件
}
struct stu *change(struct stu *head) //第五部分:修改结点内容
{
int b,a,c;
struct stu *p;
if(head->next==NULL)// 头文件为空时,输出通讯录为空
printf("**********************************通讯录为空!!!*********************************\n\n\n");
else
{
printf(" 输入要修改学生学号:");
scanf("%d",&a);
for(p=head->next;p!=NULL;p=p->next)
{
start:printf(" 输入想要修改什么?\n");
printf("\t\t\t 1:修改姓名\n");
printf("\t\t\t 2:修改学号\n");
printf("\t\t\t 3:修改年级\n");
printf("\t\t\t 4:手机\n");
printf("\t\t\t 5:电话\n");
printf("\t\t\t 6:邮件\n");
printf("\t\t\t 7:地址\n");
printf("\t\t\t 8:邮编\n");
printf(" 请输入你的选择:");
scanf("%d",&b);
switch(b)//先通过学号找到该学生,然后用switch语句选择修改项,再用switch和goto语句实现是否循环
{
case 1:
printf("\t输入新姓名:");
scanf("%s",p->name);break;
case 2:printf("\t输入新学号:");
scanf("%d",&p->xh);break;
case 3:
printf("\t输入新的年级:");
scanf("%d",&p->grade);break;
case 4:
printf("\t输入新的手机号:");
scanf("%s",p->cel);break;
case 5:
printf("\t输入新的电话号:");
scanf("%s",p->tel);break;
case 6:
printf("\t输入新的邮箱:");
scanf("%s",p->mail);break;
case 7:
printf("\t输入新的地址:");
scanf("%s",p->add);break;
case 8:
printf("\t输入新的邮编;");
scanf("%s",p->post);break;
default: printf("输入操作错误,请重新输入:");
}
printf("修改成功!!!\n");
printf(" 是否要修改其他项? 1:是 2:否\n");
printf(" 请输入你的选择:");
scanf("%d",&c);
switch(c) //goto语句实现是否循环
{
case 1:goto start;
case 2:break;
}
}
}
return head; //返回头文件
}
void printall(struct stu *head) //第六部分:输出全部通讯录
{
struct stu *p=head->next;
while(1)
{
if(p==NULL)
{
printf("**********************************通讯录为空!!!*********************************\n\n\n");
break;
}
else if(p->next==NULL)
{
printf(" ★姓名:");puts(p->name);
printf("\t学号:");printf("%d\n",p->xh);
printf("\t年级:");printf("%d\n",p->grade);
printf("\t手机:");puts(p->cel);
printf("\t电话:");puts(p->tel);
printf("\t邮箱:");puts(p->mail);
printf("\t地址:");puts(p->add);
printf("\t邮编:");puts(p->post);
printf("输出成功!!!\n");
printf("\n\n\n");
break;
}
else
{
printf(" ★姓名:");puts(p->name);
printf("\t学号:");printf("%d\n",p->xh);
printf("\t年级:");printf("%d\n",p->grade);
printf("\t手机:");puts(p->cel);
printf("\t电话:");puts(p->tel);
printf("\t邮箱:");puts(p->mail);
printf("\t地址:");puts(p->add);
printf("\t邮编:");puts(p->post);
printf("\n");
p=p->next;
continue;
}
printf("输出成功!!!\n");
}
}
void sf(struct stu *head) //第八部分:释放结点退出系统
{
struct stu *p=head ;
printf("释放链表:\n");
while(p!=NULL)
{
head=head->next;
free(p);
p=head;
}
printf("释放链表成功!!!\n");
}
int main()// 第九部分:主函数框架
{
int cz;//操作符
struct stu *head,*q;
head=(struct stu*)malloc(sizeof(struct stu));//动态链表malloc
head->next=NULL;//使next指向下一个结点,next结点不放其他结点地址
system("color 1e");//修改dos窗口前背景色,用两个十六进制数表示
printf("班级: 姓名: 学号: 设计课题:个人通讯录管理系统\n");
printf("\n********************************C语言课程设计***********************************\n");
printf(" *******************★个人通讯录管理系统★*****************\n\n\n");
printf(" * 1:新建通讯录 *\n");
printf(" * 2:删除通讯录 *\n");
printf(" * 3:修改通讯录 *\n");
printf(" * 4:查询通讯录 *\n");
printf(" * 5:显示全部记录 *\n");
printf(" * 6:释放链表并结束程序 *\n");
printf(" *********************************************************\n");
start :printf("输入操作符1-6:");//"输入操作符1-
scanf("%d",&cz);
switch(cz)//switch语句
{
case 1:
q=(struct stu *)malloc(sizeof(struct stu));
printf("\t输入姓名:");scanf("%s",q->name);
printf("\t输入学号:");scanf("%d",&q->xh);
printf("\t输入年级:");scanf("%d",&q->grade);
printf("\t手机号:");scanf("%s",q->cel);
printf("\t家庭电话:");scanf("%s",q->tel);
printf("\t输入电子邮件:");scanf("%s",q->mail);
printf("\t通讯录地址:");scanf("%s",&q->add);
printf("\t输入邮编:");scanf("%s",&q->post);
charu(head,q);
printf("插入成功!!!\n");break;
case 2://删除
head=del(head);break;
case 3:
change(head);break;//修改学生信息
case 4:
search(head);break;//查找结点head
case 5:
printall(head);break; //保存文件
case 6: //释放结点退出系统
sf(head);
exit (0);
default: printf("输入操作错误,重新"); //什么也不符合就"输入操作错误,重新"
}
goto start;//用goto语句实现循环操作
return 0;
}