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,一经查实,立即删除!

相关文章

llinux mysql_linux下安装mysql

环境:OS:Linux As 5mysql:5.61.下载跟OS相应的版本[rootnode2 soft]# uname -aLinux node2 2.6.18-274.el5 #1 SMP Fri Jul 8 17:36:59 EDT 2011 x86_64 x86_64 x86_64 GNU/Linux我这里是64位的linux,所有相应的下载64位的mysqlMySQL-5.6.19-1.rhel5.x86_64.rpm-bundle.tar2.解…

java中将字符串顺序反传转_如何在Java中将字符串序列化的Erlang术语反序列化为JInterface对象?...

我的接口系统提供了来自Erlang世界的结果&#xff0c;该结果发送了erlang术语的字符串表示形式&#xff0c;例如元组列表&#xff1a;[ {"key1" , ["AAA","BBB"] } , {"key2" , ["CCC","DDD"] } ]在Java中收到此字…

mysql archieve_mysql的archive储存引擎

archive储存引擎的应用场景就是它的名字的缩影&#xff0c;主要用于归档。archive储存引擎仅支持select和insert&#xff0c;最出众的是插入快&#xff0c;查询快&#xff0c;占用空间小。例如我们有大量的历史数据极少访问又不能删除&#xff0c;需要保存&#xff0c;那么它是…

java bip-39_Java中对XML的解析详解

先简单说下前三种方式&#xff1a;DOM方式&#xff1a;个人理解类似.net的XmlDocument&#xff0c;解析的时候效率不高&#xff0c;占用内存&#xff0c;不适合大XML的解析&#xff1b;SAX方式&#xff1a;基于事件的解析&#xff0c;当解析到xml的某个部分的时候&#xff0c;会…

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…

app+java_‎App Store 上的“Java大全”

*****Java程序员的给力推荐-Java大全&#xff1b;-----涵盖了java程序员入门、高级开发、编程题等内容&#xff1b;-----十分适合java入门、java开发、java面试人士参考使用。***内容目录&#xff1a;Java教程1.Java快速入门2.Java JDK安装和配置3.Java基本语法4.Java对象和类5…

128位java_Java:如何使用CFB和无填充实现128位AES

有人能给我带来这个问题吗&#xff1f;我需要知道如何使用AES加密和解密&#xff0c;至少使用128位CFB和无填充。一些代码或链接将非常赞赏。 (我已经看过谷歌&#xff0c;但没有幸运的艰难)。更新&#xff1a;工作正常&#xff01;public byte[] crypt() {byte[] crypt null;…

java的md5盐值加密_MD5盐值加密

import java.security.MessageDigest;import java.util.Random;import org.apache.commons.codec.binary.Hex;public class PasswordUtil {/*** 生成含有随机盐的密码*/public static String generate(String password) {Random r new Random();StringBuilder sb new StringB…

python etree模块所有函数详解_Python3使用xml.dom.minidom和xml.etree模块儿解析xml文件,封装函数...

from xml.dom.minidom importparse, parseStringfrom xml.etree importElementTreeimportxml.dom.minidom"""Get XML String info 查询属性值response:xml stringtag:xml tagelement:xml attribute"""defget_xml_info(response, element):DOMTre…

java分布式锁工具类_java 通过redis实现分布式锁

1. 开局在多线程环境中&#xff0c;经常会碰到需要加锁的情况&#xff0c;由于现在的系统基本都是集群分布式部署&#xff0c;JVM的lock已经不能满足分布式要求&#xff0c;分布式锁就这样产生了。。。百度一下&#xff0c;网上有很多分布式锁的方案或者例子&#xff0c;琳琅满…

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 …

php设置上传文件大小限制_php修改上传文件大小限制实例详解

php修改上传文件大小限制实例详解php在默认情况下&#xff0c;只允许上传一定大小的文件&#xff0c;当上传文件大小超过这个值时&#xff0c;将会出错。本文章将向大家讲解php.ini中如何修改上传文件大小限制。需要修改的设置有三个地方&#xff0c;请看下文&#xff1a;1、 修…

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

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

php 获取 uri,获取URI地址

前台和后台的URI路由地址&#xff1a;APP目录/控制器文件/方法函数会员中心的URI路由地址&#xff1a;member/APP目录/控制器文件/方法函数通过动态地址获取URL:index.php?sAPP目录&c控制器文件&m方法函数获取当控制器的URI地址&#xff1a;\Phpcmf\Service::L(Router…

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

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

php 生成验证码干扰元素,PHP生成指定位数验证码与可控干扰元素第二篇

这篇文章介绍的内容是关于PHP生成指定位数验证码与可控干扰元素第二篇&#xff0c;有着一定的参考价值&#xff0c;现在分享给大家&#xff0c;有需要的朋友可以参考一下生成验证码&#xff1a;文件名为&#xff1a;buildVerifyCode.func.php<?php //生成指定位数可控混合验…

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…