要求用C语言风格写一段程序设计 实现以下功能 1、数据输入 2、数据显示 3、数据追加 4、数据查询 按学号查询 按姓名查询 按楼号查询 按寝室号查询 5、数据修改 6、数据统计 7、数据删除 8、数据保存 9、数据读取 10、退出程序

时间: 2023-12-23 19:03:24 浏览: 20
好的,根据您的需求,我可以为您提供以下C语言程序段: #include<stdio.h> #include<stdlib.h> #include<string.h> #define MAX_SIZE 100 struct student{ char id[10]; //学号 char name[20]; //姓名 int building; //楼号 int dorm; //寝室号 }stu[MAX_SIZE]; int count = 0; //学生人数 void menu(){ //菜单界面 printf("\n"); printf("*********************\n"); printf(" 学生管理系统 \n"); printf("*********************\n"); printf("1、数据输入\n"); printf("2、数据显示\n"); printf("3、数据追加\n"); printf("4、数据查询\n"); printf("5、数据修改\n"); printf("6、数据统计\n"); printf("7、数据删除\n"); printf("8、数据保存\n"); printf("9、数据读取\n"); printf("10、退出程序\n"); printf("\n"); } void input(){ //数据输入 if(count >= MAX_SIZE){ printf("人数已到达最大值,无法继续添加\n"); return; } printf("请输入学号、姓名、楼号、寝室号,以空格分隔:\n"); scanf("%s%s%d%d", stu[count].id, stu[count].name, &stu[count].building, &stu[count].dorm); count ++; printf("数据输入成功!\n"); } void output(){ //数据显示 if(count == 0){ printf("暂无数据\n"); return; } printf("序号\t学号\t姓名\t楼号\t寝室号\n"); for(int i=0; i<count; i++){ printf("%d\t%s\t%s\t%d\t%d\n", i+1, stu[i].id, stu[i].name, stu[i].building, stu[i].dorm); } } void append(){ //数据追加 if(count >= MAX_SIZE){ printf("人数已到达最大值,无法继续添加\n"); return; } printf("请输入要追加的学生信息:\n"); scanf("%s%s%d%d", stu[count].id, stu[count].name, &stu[count].building, &stu[count].dorm); count ++; printf("数据追加成功!\n"); } void search(){ //数据查询 int type; printf("按学号查询请输入1,按姓名查询请输入2,按楼号查询请输入3,按寝室号查询请输入4:\n"); scanf("%d", &type); char keyword[20]; printf("请输入查询关键字:\n"); scanf("%s", keyword); int flag = 0; printf("序号\t学号\t姓名\t楼号\t寝室号\n"); for(int i=0; i<count; i++){ if(type == 1 && strcmp(stu[i].id, keyword) == 0){ printf("%d\t%s\t%s\t%d\t%d\n", i+1, stu[i].id, stu[i].name, stu[i].building, stu[i].dorm); flag = 1; } else if(type == 2 && strcmp(stu[i].name, keyword) == 0){ printf("%d\t%s\t%s\t%d\t%d\n", i+1, stu[i].id, stu[i].name, stu[i].building, stu[i].dorm); flag = 1; } else if(type == 3 && stu[i].building == atoi(keyword)){ printf("%d\t%s\t%s\t%d\t%d\n", i+1, stu[i].id, stu[i].name, stu[i].building, stu[i].dorm); flag = 1; } else if(type == 4 && stu[i].dorm == atoi(keyword)){ printf("%d\t%s\t%s\t%d\t%d\n", i+1, stu[i].id, stu[i].name, stu[i].building, stu[i].dorm); flag = 1; } } if(!flag){ printf("未找到匹配数据\n"); } } void modify(){ //数据修改 char keyword[20]; printf("请输入要修改的学生学号:\n"); scanf("%s", keyword); int flag = 0; for(int i=0; i<count; i++){ if(strcmp(stu[i].id, keyword) == 0){ printf("请输入修改后的学号、姓名、楼号、寝室号,以空格分隔:\n"); scanf("%s%s%d%d", stu[i].id, stu[i].name, &stu[i].building, &stu[i].dorm); printf("修改成功!\n"); flag = 1; break; } } if(!flag){ printf("未找到匹配数据\n"); } } void statistics(){ //数据统计 if(count == 0){ printf("暂无数据\n"); return; } int total = 0; for(int i=0; i<count; i++){ if(stu[i].building == 1){ total ++; } } printf("一号楼有%d位学生入住\n", total); } void del(){ //数据删除 char keyword[20]; printf("请输入要删除的学生学号:\n"); scanf("%s", keyword); int flag = 0; for(int i=0; i<count; i++){ if(strcmp(stu[i].id, keyword) == 0){ for(int j=i; j<count-1; j++){ stu[j] = stu[j+1]; } count --; printf("删除成功!\n"); flag = 1; break; } } if(!flag){ printf("未找到匹配数据\n"); } } void save(){ //数据保存 FILE* fp; fp = fopen("data.txt", "w"); for(int i=0; i<count; i++){ fprintf(fp, "%s %s %d %d\n", stu[i].id, stu[i].name, stu[i].building, stu[i].dorm); } fclose(fp); printf("数据保存成功!\n"); } void read(){ //数据读取 FILE* fp; fp = fopen("data.txt", "r"); while(fscanf(fp, "%s%s%d%d", stu[count].id, stu[count].name, &stu[count].building, &stu[count].dorm) == 4){ count ++; } fclose(fp); printf("数据读取成功!\n"); } int main(){ int choice; do{ menu(); printf("请输入选项(1-10):\n"); scanf("%d", &choice); switch(choice){ case 1: input(); break; case 2: output(); break; case 3: append(); break; case 4: search(); break; case 5: modify(); break; case 6: statistics(); break; case 7: del(); break; case 8: save(); break; case 9: read(); break; case 10: printf("感谢使用,再见!\n"); break; default: printf("输入有误,请重新输入!\n"); break; } }while(choice != 10); return 0; }

相关推荐

最新推荐

recommend-type

单片机C语言程序设计:用计数器中断实现100以内的按键计数

名称:用计数器中断实现 100 以内的按键计数 说明:本例用 T0 计数器中断实现按键技术,由于计数寄存器初值为 1,因此 P3.4 引脚的每次负跳变都会触发 T0 中断,实现计数值累加。计数器的清零用外部中断 0 控制。
recommend-type

单片机C语言程序设计:8X8LED 点阵显示数字

名称:按键控制 8X8LED 点阵屏显示图形 说明:每次按下 K1 时,会使 8X8LED点阵屏循环显示不同图形。本例同时使用外部中断和定时中断。
recommend-type

单片机C语言程序设计:定时器控制数码管动态显示

名称:定时器控制数码管动态显示 说明:8 个数码管上分两组动态显示年月日与时分秒,本例的位显示延时用定时器实现。
recommend-type

C语言程序设计实现区号查询系统C语言程序设计实现

用C语言编程的区号查询系统,要求实现区号查询系统中,添加新记录、删除记录、显示记录信息、按城市查找信息和退出系统等功能。 ①录入有关城市的名称和区号。 ②显示所有城市的信息。 ③通过输入城市名称查找对应...
recommend-type

用C语言实现从文本文件中读取数据后进行排序的功能

是一个十分可靠的程序,这个程序的查错能力非常强悍。程序包含了文件操作,归并排序和字符串输入等多种技术。对大家学习C语言很有帮助,有需要的一起来看看。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。