#include <stdio.h>
#include <stdlib.h>
#include <string.h> typedef struct student
{
int id;
char name[];
int age;
char sex;
char birthday[];
char address[];
char phone[];
char email[];
struct student *next;
}student; student *head = NULL;
int length;
void create()
{
student *p1,*p2;
length = ;
p1 = (student *)malloc(sizeof(student));
p1->id = -;
if(head == NULL)
{
head = p1;
}
printf("请输入学生的学号、姓名、年龄、性别、出生年月、地址、电话、电子邮箱:\n");
while()
{
p2 = (student *)malloc(sizeof(student));
scanf("%d %s %d %c %s %s %s %s",&p2->id,p2->name,&p2->age,&p2->sex,&p2->birthday,&p2->address,p2->phone,p2->email);
if(p2->id == )
{
printf("链表创建完成!\n");
break;
}
length ++;
p1->next = p2;
p2->next = NULL;
p1 = p1->next;
}
return ;
} void LoadStudentInFromFile()
{
student *p,*q;
int c;
FILE* f;
f = fopen("input.txt","rb");
if(f == NULL)
{
return ;
}
fseek(f,,SEEK_SET);
p = (student *)malloc(sizeof(student));
p->next = NULL;
head = p;
while(!feof(f))
{
c = fgetc(f);
if(c != -)
{
fseek(f,-,SEEK_CUR);
}
else
{
return ;
}
q = (student *)malloc(sizeof(student));
fscanf(f,"%d",&q->id);
fscanf(f,"%s",q->name);
fscanf(f,"%d",&q->age);
fscanf(f,"%c",&q->sex);
fscanf(f,"%s",q->birthday);
fscanf(f,"%s",q->address);
fscanf(f,"%s",q->phone);
fscanf(f,"%s",q->email);
q->next = NULL;
p->next = q;
p = p->next;
length ++;//链表长度
}
} void ModifyStudentInfo()
{
student *p = head->next;
int num;
printf("请输入要修改的学生的学号:");
scanf("%d",&num);
while(p != NULL)
{
if(p->id == num)
{
printf("修改前,学号为%d的学生信息如下:\n",num);
printf("%d %s %d %c %s %s %s %s",p->id,p->name,p->age,p->sex,p->birthday,p->address,p->phone,p->email);
printf("请输入学生的新电话:");
getchar();
gets(p->phone);
printf("请输入学生的新地址:");
gets(p->address);
printf("修改后,学号为%d的学生信息如下:\n",num);
printf("%d %s %d %c %s %s %s %s",&p->id,p->name,&p->age,p->sex,p->birthday,p->address,p->phone,p->email);
return ;
}
p = p->next;
}
if(p == NULL)
{
printf("该学号不存在!\n");
return ;
}
}
void display()
{
student *p = head->next;
printf("链表中所有的学生信息如下:\n");
while(p != NULL)
{
printf("%d %s %d %c %s %s %s %s",p->id,p->name,p->age,p->sex,p->birthday,p->address,p->phone,p->email);
printf("\n");
p = p->next;
}
return ;
} void search()
{
int num,x;
char name[];
student *p = head->next;
printf("请选择查询方式:\n");
printf("1、按学号查询\t2、按姓名查询\n");
scanf("%d",&x);
if(x == )
{
printf("需要查找的学生学号为:");
scanf("%d",num);
while(p != NULL)
{
if(p->id == num)
{
printf("学号为%d的学生信息如下:\n",num);
printf("%d %s %d %c %s %s %s %s",p->id,p->name,p->age,p->sex,p->birthday,p->address,p->phone,p->email);
return ;
}
p = p->next;
}
if(p == NULL)
{
printf("无此记录!\n");
}
}
else if(x == )
{
printf("需要查找的学生姓名为:");
getchar();
gets(name);
p = head->next;
while(p != NULL)
{
if(strcmp(p->name,name) == )
{
printf("学生姓名为%s的学生信息如下:\n",name);
printf("%d %s %d %c %s %s %s %s",p->id,p->name,p->age,p->sex,p->birthday,p->address,p->phone,p->email);
return ;
}
p = p->next;
}
if(p == NULL)
{
printf("无此记录!\n");
}
}
return ;
} void insert()
{
int num,i;
student *p,*q;
p = head; printf("请输入你要插入的位置:");
scanf("%d",&num);
if(num > length)
{
printf("找不到插入的位置\n");
return ;
}
else
{
printf("请输入你要插入的学生的信息:\n");
q = (student *)malloc(sizeof(student));
scanf("%d %s %d %c %s %s %s %s",&q->id,q->name,&q->age,&q->sex,q->birthday,q->address,q->phone,q->email);
while(p != NULL)
{
if(p->id == q->id)
{
printf("该学号已经存在,无法插入!\n");
return ;
}
p = p->next;
}
p = head;
for(i=; i<num; ++i)
{
p = p->next;
}
q->next = p->next;
p->next = q;
length ++;
printf("插入成功!\n");
return ;
}
} void Delete()
{
int num;
student *p,*q;
q = head;
p = head->next;
printf("请输入要删除的学生的学号:\n");
scanf("%d",&num); while(p != NULL)
{
if(p->id == num)
{
q->next = p->next;
free(p);
length --;
printf("删除成功!\n");
return ;
}
p = p->next;
q = q->next;
}
if(p == NULL)
{
printf("找不到要删除的编号!\n");
return ;
}
} void menu()
{
printf("___________________________________________________\n");
printf("| 学生信息管理系统 |\n");
printf("| 0、退出系统 |\n");
printf("| 1、录入学生信息 |\n");
printf("| 2、建立链表 |\n");
printf("| 3、显示链表 |\n");
printf("| 4、查找链表中的某个元素 |\n");
printf("| 5、删除链表中指定学号的结点 |\n");
printf("| 6、指定位置上插入一个新结点 |\n");
printf("| 7、修改学生信息 |\n");
printf("__________________________________________________\n");
return ;
} int main(void)
{
int a;
menu();
while()
{
printf("请输入相应的功能:");
scanf("%d",&a);
switch(a)
{
case :
return ;
case :
LoadStudentInFromFile();
menu();
break;
case :
create();
menu();
break;
case :
if(head)
{
display();
menu();
}
else
{
printf("链表为空,请先建立链表!\n");
menu();
}
break;
case :
if(head)
{
search();
menu();
}
else
{
printf("链表为空,请先建立链表!\n");
menu();
}
break;
case :
if(head)
{
Delete();
menu();
}
else
{
printf("链表为空,请先建立链表!\n");
menu();
}
break;
case :
if(head)
{
insert();
menu();
}
else
{
printf("链表为空,请先建立链表!\n");
menu();
}
break;
case :
if(head)
{
ModifyStudentInfo();
menu();
}
else
{
printf("链表为空,请先建立链表!\n");
menu();
}
break;
default:
break;
}
}
system("pause");
return ;
}

学生信息管理系统(C语言)的更多相关文章

  1. 学生信息管理系统(c语言)

    ①注意: 程序中使用了sleep()函数.system()函数 关于 sleep() 函数 sleep() 函数的头文件和用法会因环境的不同而有所不同. 具体见-sleep()函数功能及用法 关于sy ...

  2. C语言练习-学生信息管理系统

    题目要求: 学生信息管理系统struct studentInfo{ int id; char name[128]; int age; char sex; int c_score; int cpp_sc ...

  3. 【转载】C语言综合实验1—学生信息管理系统

    http://www.cnblogs.com/Anker/archive/2013/05/06/3063436.html 实验题目:学生信息管理系统 实验要求:用户可以选择1-7可以分别进行学生信息的 ...

  4. C语言小练习之学生信息管理系统

    C语言小练习之学生信息管理系统 main.c文件   1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 2 ...

  5. 大一C语言结课设计之《学生信息管理系统》

    第一次写这么长的程序,代码仅供參考,有问题请留言. /* ** 学生信息管理系统 ** IDE:Dev-Cpp 4.9.9.2 ** 2014-6-15 */ #include <stdio.h ...

  6. 基于数组或链表的学生信息管理系统(小学期C语言程序实训)

    1.基于数组的学生信息管理系统 实验内容: 编写并调试程序,实现学校各专业班级学生信息的管理.定义学生信息的结构体类型,包括:学号.姓名.专业.班级.3门成绩. 实验要求: (1) main函数:以菜 ...

  7. 【Python3.6+Django2.0+Xadmin2.0系列教程之二】学生信息管理系统(入门篇)

    上一篇我们已经创建好了一个Xadmin的基础项目,现在我们将在此基础上构建一个同样很基础的学生信息管理系统. 一.创建模型 模型是表示我们的数据库表或集合类,并且其中所述类的每个属性是表或集合的字段, ...

  8. 基于Spring MVC + Spring + MyBatis的【学生信息管理系统】

    资源下载:https://download.csdn.net/download/weixin_44893902/45603211 练习点设计: 模糊查询.删除.新增 一.语言和环境 实现语言:JAVA ...

  9. 基于数据库MySQL的简易学生信息管理系统

    通过这几天学习Mysql数据库,对其也有了基本的了解,为了加深印象,于是就写了一个最简易的学生信息管理系统. 一:基本要求 1.通过已知用户名和密码进行登录: 2.可以显示菜单: 3.可以随时插入学生 ...

随机推荐

  1. [js]js栈内存的全局/私有作用域,代码预解释

    js代码如何执行的 浏览器提供执行环境: 全局作用域(提供js执行环境, 栈内存) --> 执行js需要预解释 - 带var : 提前声明 - 带function关键字的: 提前声明+定义 js ...

  2. Nginx、Tomcat配置https

    一.Nginx.Tomcat配置https 前提就是已经得到了CA机构颁发的证书 一.合并证书 1.假设证书文件如下 秘钥文件server.key,证书CACertificate-INTERMEDIA ...

  3. npm 发布一个全局的指令

    我们经常使用 npm i  -g  xxxx 安装完成一个包之后,就能直接使用对应的指令.例如安装  vue-cli 或者 express 等 那么下面我们自己做一个类似的效果: 首先要对 npm 发 ...

  4. enzyme design 整体流程及感想

    想起什么来写什么吧. 整体流程(以Ceas2, TPP, G3P为例): 准备蛋白即配体参数文件: 设置CST文件: 准备protocol和flag文件: 运行enzyme_design: 结果处理. ...

  5. PHP on CentOS (LAMP) and wordpress

    http://php.net/manual/zh/install.windows.php https://www.unixmen.com/install-wordpress-centos-7-linu ...

  6. Deeplab v3+中的骨干模型resnet(加入atrous)的源码解析,以及普通resnet整个结构的构建过程

    加入带洞卷积的resnet结构的构建,以及普通resnet如何通过模块的组合来堆砌深层卷积网络. 第一段代码为deeplab v3+(pytorch版本)中的基本模型改进版resnet的构建过程, 第 ...

  7. ZooKeeper是什么

    ZooKeeper概念 相信大家对 ZooKeeper 应该不算陌生,但是你真的了解 ZooKeeper 是什么吗?如果别人/面试官让你讲讲 ZooKeeper 是什么,你能回答到哪个地步呢? 本人曾 ...

  8. window中普通用户无法登录远程桌面

    解决方案就是将该用户加到 Remote Desktop Users 这个用户组中. 使用命令 net localgroup "Remote Desktop Users" 用户名 / ...

  9. Shell 脚本格式注意事项

    if 条件判断格式 if [ ! -f file.txt ];then cmd else cmd fi 注1:! 代表非.不存在文件就成功. 注2:再有参数 变量 需要 [] 阔起 1 运算书写写格式 ...

  10. python中多继承C3算法研究

    在python的面向对象继承问题中,单继承简单易懂,全部接受传承类的属性,并可添加自带属性, 但是,在多继承情况下,会遇到多个被继承者的顺序问题,以及多次继承后查找前几次继承者需求属性时,可能不易发现 ...