java用链表做学生系统_C语言链表实现学生管理系统

本文实例为大家分享了C语言链表实现学生管理系统的具体代码,供大家参考,具体内容如下

9e8ed5ce8a2813019a08a6af4b43371c.png

#include

#include

#include

#include

#include

#include

using namespace std;

typedef struct ndoe{

char id[10];

char name[10];

char sex[3];

char num[10];

struct node *next;

}student;

struct Student{

student data;

struct Student *next;

};

/********创建学生信息**********/

Student * insert(Student * head){

Student * s,*r;

head=(Student *)malloc(sizeof(Student));

printf("请输入学生的个数:");

int n;

scanf("%d",&n);

r=head;

printf("按照“学号 姓名 性别(M or G) 手机号”的形式输入每个学生的信息\n");

for(int i=0;i

s=(Student *)malloc(sizeof(Student));

/*scanf("%s",s->data.id);

scanf("%s",s->data.name);

scanf("%s",s->data.sex);

scanf("%s",s->data.num);*/

scanf("%s%s%s%s",s->data.id,s->data.name,s->data.sex,s->data.num);

r->next=s;

r=s;

}

r->next=NULL;

printf("录入成功\n");

return head;

}

/********增加学生************/

void add(Student *head){

Student *s;

s=head->next;

while(s->next!=NULL)

s=s->next;

Student *ad=(Student *)malloc(sizeof(Student));

ad->next=NULL;

s->next=ad;

//printf("输入新学生的信息:\n");

scanf("%s%s%s%s",ad->data.id,ad->data.name,ad->data.sex,ad->data.num);

printf("添加成功\n");

return ;

}

/*************修改学生信息********************/

void change(Student * head){

printf("输入1,按学号搜索学生,并修改改学生的信息\n");

printf("输入2,按姓名搜索学生,并修改改学生的信息\n");

Student * s;

int n;

scanf("%d",&n);

switch(n){

case 1:{

printf("请输入学号:");

char number[10];

scanf("%s",number);

s=head->next;

while(s!=NULL){

if(strcmp(s->data.id,number)==0){

printf("请输入要修改的信息:");

char phone[10];

scanf("%s",phone);

strcpy(s->data.num,phone);

printf("修改成功\n");

break;

}

s=s->next;

}

break;

}

case 2:{

printf("请输入姓名:");

char nam[10];

scanf("%s",&nam);

s=head->next;

while(s!=NULL){

if(strcmp(s->data.name,nam)==0){

printf("请输入要修改的信息:");

char phone[10];

scanf("%s",phone);

strcpy(s->data.num,phone);

printf("修改成功\n");

break;

}

s=s->next;

}

break;

}

}

return ;

}

/**********删除学生信息******************/

void del(Student * head){

printf("输入1,按学号搜索学生,并删除该学生的信息\n");

printf("输入2,按姓名搜索学生,并删除该学生的信息\n");

Student * s,*r;

int n;

scanf("%d",&n);

switch(n){

case 1:{

printf("请输入学号:");

char number[10];

scanf("%s",number);

s=head->next;

r=head;

while(s!=NULL){

if(strcmp(s->data.id,number)==0){

r->next=s->next;

free(s);

printf("删除成功\n");

break;

}

r=s;

s=s->next;

}

break;

}

case 2:{

printf("请输入姓名:");

char nam[10];

scanf("%s",&nam);

s=head->next;

r=head;

while(s!=NULL){

if(strcmp(s->data.name,nam)==0){

r->next=s->next;

free(s);

printf("删除成功\n");

break;

}

r=s;

s=s->next;

}

break;

}

}

return ;

}

/**********查询学生的信息**********************/

void check(Student * head){

printf("输入1,按学号搜索学生,并展示该学生的信息\n");

printf("输入2,按姓名搜索学生,并展示该学生的信息\n");

Student * s,r;

int n;

scanf("%d",&n);

switch(n){

case 1:{

printf("请输入学号:");

char number[10];

scanf("%s",number);

s=head->next;

while(s!=NULL){

if(strcmp(s->data.id,number)==0){

printf("%s %s %s %s\n",s->data.id,s->data.name,s->data.sex,s->data.num);

break;

}

s=s->next;

}

break;

}

case 2:{

printf("请输入姓名:");

char nam[10];

scanf("%s",&nam);

s=head->next;

while(s!=NULL){

if(strcmp(s->data.name,nam)==0){

printf("%s %s %s %s\n",s->data.id,s->data.name,s->data.sex,s->data.num);

break;

}

s=s->next;

}

break;

}

}

if(s==NULL)

printf("该学生不存在\n");

return ;

}

int main(){

Student *head=NULL;

Student *a;

printf("***欢迎进入学生管理系统***\n");

printf("***1:请录入学生信息***\n");

printf("***2:请修改学生信息***\n");

printf("***3:请删除学生信息***\n");

printf("***4:请查询学生信息***\n");

printf("***5:请添加新学生信息**\n");

printf("***6: 退出管理系统 ***\n");

printf("*************************\n");

printf("请输入命令:");

int n;

while(scanf("%d",&n)&&n!=6){

switch(n){

case 1:{

printf("请录入学生信息:\n");

head=insert(a);

break;

}

case 2:{

printf("请改学生信息:\n");

change(head);

break;

}

case 3:{

cout<

del(head);

break;

}

case 4:{

cout<

check(head);

break;

}

case 5:{

cout<

add(head);

break;

}

default :

break;

}

printf("请继续输入命令:");

}

Student *s,*r;

s=head->next;

while(s!=NULL){

r=s->next;

free(s);

s=r;

}

free(head);

return 0;

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/442417.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 全文本检索的列_Mysql 全文本检索

mysql 全文索引注意 并非所有的引擎都支持 全文检索mysql最常用的引擎 INnodb 和 myisam 后者支持全文检索 前者不支持创建表的时候指定要检索列 CREATE TABLE TEST_FULLTEXT(note_id int not null auto_increment,note_text text null, primaty key(note_id),FULLTEXT(note_te…

java 的对象类用_java基础(第零篇)对象与类

前言&#xff1a;本文讲述java中对象与类的一些概念。包括对象与类的有关概念&#xff0c;类间五种关系&#xff0c;类的访问权限等。在java中&#xff0c;一切都可以用对象来描述&#xff0c;操作对象的标识符只不过是对象的一个引用&#xff0c;一个对象可以有多个引用&#…

buffer java nio_Java NIO深入理解Buffer(缓冲区)

前言Github&#xff1a;https://github.com/yihonglei/java-allProject&#xff1a;java-nio一 Buffer概述Java NIO中的Buffer用于和NIO通道进行交互。数据是从通道读入缓冲区&#xff0c;从缓冲区写入到通道中的。缓冲区本质上是一块可以写入数据&#xff0c;然后可以从中读取…

java robot键值_Java:使用Robot类模拟键盘, 以Alt码方式输出汉字

java.awt.Robot类Java提供java.awt.Robot类来模拟操作键盘和鼠标, 下面是一个简单的demopublic static void keyPressByInt(Robot r,int key, int time){r.keyPress(key);r.keyRelease(key);if (time > 0) {r.delay(time);}}public static void main(String[] args) throws …

java调用 火眼臻睛,火眼臻睛车牌识别SDK评测

【CPS中安网 cps.com.cn】CPS LAB总评:用专业角度解读产品--CPS评测中心对火眼臻睛车牌识别SDK进行了全面评测,火眼臻睛车牌识别SDK在综合识别率、车牌定位成功率、大角度下的识别率、夜间环境下的识别率、极端环境下的识别率、支持的最小车牌像素宽度等测试表现,都位于行业前列…

java各层级限流对比,面试官说:来谈谈限流-从概念到实现,一问你就懵逼了?...

后端服务的接口都是有访问上限的&#xff0c;如果外部qps或并发量超过了访问上限会导致应用瘫痪。所以一般都会对接口调用加上限流保护&#xff0c;防止超出预期的请求导致系统故障。从限流类型来说一般来说分为两种:并发数限流和qps限流&#xff0c;并发数限流就是限制同一时刻…

mysql and 和where,关于mysql:连接sql查询中where和and子句的区别

本问题已经有最佳答案&#xff0c;请猛点这里访问。下面两个SQL查询有什么区别和号根据以下两个测试结果速度更快(237比460)。据我所知&#xff0c;这是一个标准。。氧化镁不&#xff0c;有细微的差别&#xff0c;你不能说没有差别除了语法之外没有别的区别。虽然只有一个简短的…

matlab里输出恒压的逆变器,基于IGBT逆变器的异步电机变频调速系统的MATLAB仿真...

异步电机变频调速系统电路仿真模型如图(4)所示。直流电压不621V&#xff0c;逆变器为IGBT 的三相半桥逆变器&#xff0c;电机为异步电机模块&#xff0c;其主电路由直流电压源、逆变器和电机依次相连。图(4)变频调速系统控制部分&#xff0c;利用“Step”模块设定频率指令f1*&a…

php 获取京东交易账号,PHP爬虫爬取京东列表

这里使用到了一个php插件下面是源码simple_html_dom.phpdefined(IN_ECS);define(HDOM_TYPE_ELEMENT, 1);define(HDOM_TYPE_COMMENT, 2);define(HDOM_TYPE_TEXT, 3);define(HDOM_TYPE_ENDTAG, 4);define(HDOM_TYPE_ROOT, 5);define(HDOM_TYPE_UNKNOWN, 6);define(HDOM_QUOTE_DOU…

php dns刷新,Windows DNS缓存自动刷新

Windows DNS缓存自动刷新admin • 2018 年 09 月 04 日DNS(域名服务器)DNS(Domain Name Server)是进行域名和与之相对应的ip地址转换的服务器。DNS中保存了一张域名和与之相应的ip地址的表&#xff0c;以解析消息的域名。DNS轮训在统一主机添加多条A记录&#xff0c;这就是DNS轮…

jq上传file到php,jQuery文件上传

插件描述&#xff1a;这是一个文件上传的展示&#xff0c;看很多插件&#xff0c;并不满意就自己写了一个&#xff0c;可能兼容性不是很好&#xff0c;没有准确进行测试过&#xff0c;还请各位不吝赐教更新时间&#xff1a;2019/3/25 下午8:53:17更新说明&#xff1a;修复上传成…

linux误删表空间文件,UNDO表空间下的数据文件被误删除后的处理方法

UNDO表空间下的数据文件被误删除后的处理方法&#xff1a;操作前备份数据库&#xff0c;以避免更大的损失。思路&#xff1a;1、把误删除的数据文件offline2、正常打开数据库后创建新的UNDO表空间及数据文件3、修改相应参数指向新的UNDO表空间4、重新启动数据库验证5、删除旧的…

linux内核有ebpf吗,聊聊很重要的内核技术eBPF

在2018年的 Linux Plumber 大会上&#xff0c;eBPF成了亮点&#xff0c;有24个议题提到了 eBPF&#xff0c;可以预计eBPF会成为一大技术热点。eBPF(Extended Berkeley Packet Filter) 的核心是驻留在 kernel 的高效虚拟机。最初的目的是高效网络过滤框架&#xff0c;前身是 BPF…

oom linux 导致ssh,Linux OOM

8种机械键盘轴体对比本人程序员&#xff0c;要买一个写代码的键盘&#xff0c;请问红轴和茶轴怎么选&#xff1f;某个机器看到一条日志:Out of Memory: Kill process xxx (xxx) score 707 or sacrifice child并且syslog, ssh等进程都被kill掉了.简单了解了下OOM(Out of Memory)…

c语言bfs程序讲解,面试算法--二叉树DFS/BFS实现(C语言)

深度优先搜索算法(Depth First Search)DFS是搜索算法的一种。它沿着树的深度遍历树的节点&#xff0c;尽可能深的搜索树的分支。当节点v的所有边都己被探寻过&#xff0c;搜索将回溯到发现节点v的那条边的起始节点。这一过程一直进行到已发现从源节点可达的所有节点为止。如果还…

c语言 子进程,子Shell和子进程

Shell 中有很多方法产生子进程&#xff0c;比如以新进程的方式运行 Shell 脚本&#xff0c;使用组命令、管道、命令替换等&#xff0c;但是这些子进程是有区别的。子进程的概念是由父进程的概念引申而来的。在 Linux 系统中&#xff0c;系统运行的应用程序几乎都是从 init(pid为…

学C语言办公本和游戏本,为什么不建议买游戏本?入手前须知,别只看中游戏...

原标题&#xff1a;为什么不建议买游戏本&#xff1f;入手前须知&#xff0c;别只看中游戏作为一名游戏本用户&#xff0c;我自己在用的游戏本已经用了四五年的时间了&#xff0c;从最初的大学生到毕业工作2年时间&#xff0c;这一游戏本给我带来了不少麻烦。最大的麻烦就是“笨…

Android ui 单元测试 覆盖率,Android单元测试—UI测试(Espresso)

前言我们先回顾一下&#xff0c;在上一篇博客中&#xff0c;主要分享了Android单元测试的逻辑测试部分。接下来&#xff0c;我们重点讲解Android单元测试的UI测试部分&#xff01;何为UI测试呢&#xff1f;就是对用户界面的交互元素进行测试&#xff0c;如TextView、ImageView&…

android shape 圆角百分比,Android shape显示圆角问题

当需要定义一个圆角效果,当在ADT中预览,没有有效果时,只要运行就可以了&#xff01;xmlns:Android"http://schemas.android.com/apk/res/android">android:state_pressed"true">android:startColor"#ff8c00"android:endColor"#FFFFFF…

android 删除垃圾文件夹,别再用手机管家清理垃圾了!删除这些文件夹,内存瞬间释放几个G...

随着手机使用时间的增加&#xff0c;手机中缓存的东西越来越多&#xff0c;这时候手机内存空间就会告急&#xff0c;从而影响手机的流畅性。那么在这种时候不要乱清理&#xff0c;我们只需要删除这几个文件夹&#xff0c;就可以帮手机轻松释放好几个G的内存。下面我们就一起来看…