一个简单的学生宿舍管理系统(c语言)

2024-01-09 23:20

本文主要是介绍一个简单的学生宿舍管理系统(c语言),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

该程序是一个学生宿舍管理系统,具有以下功能:

  1. 添加学生信息:可以输入学号、姓名、性别、宿舍、联系方式和家庭住址,将学生信息添加到系统中。

  2. 查询学生信息:可以根据学号或姓名查询学生信息,并将查询结果打印出来。

  3. 删除指定学生的记录:可以根据学号或姓名删除指定学生的记录。

  4. 修改指定学生的记录:可以根据学号修改指定学生的姓名、性别、宿舍、联系方式和家庭住址。

  5. 打印学生信息:将系统中所有学生的信息打印出来。

  6. 保存退出:将学生信息保存并退出程序。

#include<stdio.h>
#include <conio.h>
#include<string.h>
#include <stdlib.h>
#include<windows.h>
typedef int datatype;
typedef struct s1                         //为struct s1取一个别名为STUDENT
{char       no[15] ;                      //学号char       name[15] ;                   //学生姓名char      score[20];                   //联系方式char      sushe[15];                   //宿舍 char      xingbei[10];                 //学生性别 char       hom[20] ;                 //学生家庭住址 struct s1  *next ;                    //指向后继结点的指针int          n;                       //添加学生信息的数量 
}changfa,*linklist;void InputData(linklist &H){            //添加学生信息linklist r,p;r=H;p=(linklist)malloc(sizeof(changfa));int i;printf("输入学号:");scanf("%s",p->no);printf("输入姓名:");scanf("%s",p->name);printf("输入性别(男或女):");scanf("%s",p->xingbei);printf("输入宿舍:");scanf("%s",p->sushe);printf("输入联系方式:");scanf("%s",p->score);printf("输入家庭住址:");scanf("%s",p->hom);p->next = r->next;r->next = p;printf("添加成功\n");getch();
}
void PrintMenu( )
{printf("\n\n");printf("***********************************************\n");printf("*                学生宿舍管理系统             *\n");printf("*   1. 添加学生信息                           *\n");printf("*   2. 查询学生信息(学号或姓名)             *\n");printf("*   3. 删除指定学生的记录                     *\n");printf("*   4. 修改指定学生的记录                     *\n");printf("*   5. 打印学生信息                           *\n");printf("*   6. 保存退出                               *\n");printf("***********************************************\n");printf("\n输入要进行的操作(1-6):");
}
int MenuSelect( )
{int key;PrintMenu();scanf("%d",&key);return(key);
}void find(linklist H)
{linklist p;char no[15]; //char name[15];                   //定义一个字符数组no,name和strint choose;int i;p=H;printf("要查询的方式(1是学号,0是姓名):");  //查询方式(姓名或学号)scanf("%d",&choose);if(choose==1){ printf("输入要查询学生的学号:");scanf("%s",no);                          //用输入语句输入一个学号存储到no中}else if(choose==0){  printf("输入要查询学生的姓名:");scanf("%s",no);                      //用输入语句输入一个姓名存储到name中}while(p!=NULL){if (strcmp(p->no,no)==0||strcmp(p->name,no)==0)              //找到了要查询的数据{break;}else{p=p->next;}}if(p!=NULL){printf("|----------------------------TUTE-------------------------|\n");printf("|    学号  |     姓名   | 性别| 宿舍 | 联系方式  |家庭住址| \n");printf("|%s|    %s    |  %s | %s  |%s|  %s  |\n",p->no,p->name,p->xingbei,p->sushe,p->score,p->hom);printf("|----------------------------TUTE-------------------------|\n"); }else{printf("没有此人");}getch();
}
void Delete( linklist &H)
{linklist q,p;p = H;q = H->next;char no[15]; //char name[15];                   //定义一个整数no(用来存储输入的学号)int choose;int flg=0;printf("要删除的方式(1是学号,0是姓名):");  //删除方式(姓名或学号)scanf("%d",&choose);if(choose!=0){ printf("输入要删除学生的学号:");scanf("%s",no);                          //用输入语句输入一个学号存储到no中}else{  printf("输入要删除学生的姓名:");scanf("%s",no);                      //用输入语句输入一个姓名存储到name中}while(q!=NULL){if (strcmp(q->no,no)==0||strcmp(q->name,no)==0)//找到了要查询的数据{flg = 1;p->next = q->next;free(q);printf("删除成功!\n");break;}else{p = q;q = q->next;}}if(flg==0) printf("未找到想删除的记录!\n");getch();
}
void change(linklist &H )   
{linklist p;                                  char no[15];  //定义一个字符数组noint i;p=H;printf("输入要修改学生的学号:");scanf("%s",no);  //用输入语句输入一个学号存储到no中while(p!=NULL){                   if (strcmp(p->no,no)==0) //找到了要查询的数据{break;}else{p=p->next;}}if(p!=NULL){printf("修改后姓名:");scanf("%s",p->name);printf("修改后性别:");scanf("%s",p->xingbei);printf("修改后宿舍:");scanf("%s",p->sushe);printf("修改后联系方式:");scanf("%s",p->score);printf("修改后地址:");scanf("%s",p->hom);printf("修该成功!\n");}else{printf("未找到需修改的记录!\n");}getch();
}
void print(linklist H)
{        linklist p;p=H->next;printf("\n");printf("|----------------------------TUTE-------------------------|\n");printf("|    学号  |     姓名   | 性别| 宿舍 | 联系方式  |家庭住址|\n");printf("|----------|------------|-----|------|-----------|--------|\n");  while(p!=NULL){printf("|%s|    %s    |  %s |  %s |%s|  %s  |\n",p->no,p->name,p->xingbei,p->sushe,p->score,p->hom);p=p->next;}printf("|----------------------------TUTE-------------------------|\n");getch();
}int main()
{linklist H=NULL;H=(linklist)malloc(sizeof(changfa));//生成新结点H->next = NULL;int key;system("color 0A");                  //改变执行窗口的背景色和字体色字体为绿色while(1)                             //死循环{system("cls");key=MenuSelect();switch(key){case 1:InputData(H);                //增加break;case 2:find(H);                  //查询学生信息(学号或姓名)break;case 3:Delete(H);                 //删除一个指定学生的记录数据break;case 4:                        //修改一个指定学生的记录数据change(H);break;case 5:                        //打印所有记录数据print(H);break;case 6:                        //退出程序exit(0);}}
}

这篇关于一个简单的学生宿舍管理系统(c语言)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588770

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu