目录
通过c语言设计一个学生管理系统,要求有直观的主菜单,可以录入学生的信息,实现添加学生信息、显示学生信息、查找学生信息、删除学生信息、修改学生信息以及退出等功能。
1、首先因为学生有以下几个基本信息:姓名、年龄、学号、性别,依次由name、age、id和sex来表示,所以可以通过结构体实现,struct语句定义存储不同类型的数据项,定义一个结构体名为student,用于存储每个学生的信息,另外定义一个结构体名为class_room班级,它包含了结构体student的变量初始化st,用于存储学生以及当前班级人数,且定义学生最大人数为60,如下代码:
#define MAX 60//定义MAX最大值为60
struct student{
char name[20];
int age;
int id;
char sex[10];
};
struct class_room{
struct student st[MAX]; //定义多个学生
int n; //当前班级的人数
};
2、由于是显示一个管理系统,所以我们设计一个主菜单,通过定义一个函数printf_menu()来实现这个功能,如下代码:
//打印主菜单函数
void printf_menu()//打印主菜单函数
{
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");
}
3、因为要通过输入相应的序号来选择相应的功能,所以可以在主函数中通过一个switch()语句来实现,若要使程序一直执行下去,通过用户输入退出才退出程序,即设置一个while(1)无限循环下去,另外还要设置一个loop语句,通过goto语句,即若输入错误的序号即跳到选择序号的页面。
访问结构的成员,通过使用运算符.来实现,即WLW.n=0,表示初始化班级WLW的成员n,而&WLW表示取WLW的地址,取出其对应存储空间的值,即存储的学生,另外若想使用指向该结构的指针来访问结构体,通过操作符->实现。
如以下代码:
//主函数
int main()
{
struct class_room WLW;//定义一个班级为WLW存储学生
WLW.n=0;//初始化,学生人数为0
while(1)//无限循环
{
loop:
printf_menu();//调用主菜单函数输出主菜单
int choose;//定义一个序号
scanf("%d",&choose);
switch(choose)
{
case 1:
add_student(&WLW);//添加学生
break;
case 2:
show_student(&WLW);//显示学生
break;
case 3:
find_student(&WLW);//查询学生
break;
case 4:
remove_student(&WLW);//删除学生
break;
case 5:
change_student(&WLW);//修改学生
break;
case 6:
return 0;//退出程序
default://若输出错误的序号,则跳转至重新输出
printf("输出错误,请重新输入!\n");
goto loop;
}
}
}
1、定义一个add_student()函数添加学生信息,参数为struct class_room *WLW,即结构体指针变量。姓名和性别由于是字符串类型,所以scanf()中通过%s格式符表示,年龄和id它们的地址是班级WLW当前学生的相应信息,由于数组名代表首地址这里不用&,另外每次添加后,当前班级的人数n++,如下代码:
//添加学生信息
void add_student(struct class_room *WLW)
{
printf("请输入学生的姓名:\n");
scanf("%s",WLW->st[WLW->n].name); //数组名代表首地址
printf("请输入学生的年龄:\n");
scanf("%d",&WLW->st[WLW->n].age); //取变量的地址
printf("请输入学生的id:\n");
scanf("%d",&WLW->st[WLW->n].id);
printf("请输入学生的性别:\n");
scanf("%s",WLW->st[WLW->n].sex);
WLW->n++;//班级人数加一
}
2、定义一个show_student()函数显示学生信息,即显示当前班级的所有学生信息,其中WLW->n为当前班级的人数,如下代码:
//显示学生信息
void show_student(struct class_room *WLW)
{
int i;
for(i=0;i<WLW->n;i++)//WLW->n为当前班级的人数
{
printf("the %d student name is %s\n",i+1,WLW->st[i].name);
printf("the %d student age is %d\n",i+1,WLW->st[i].age);
printf("the %d student id is %d\n",i+1,WLW->st[i].id);
printf("the %d student sex is %s\n",i+1,WLW->st[i].sex);
}
}
3、定义一个find_student()函数查找学生信息,通过输入学生id查找学生的信息,若存在则通过循环依次输出该学生的信息:
//查找学生
int find_student(struct class_room *WLW)
{
int id,i;
printf("请输入要查找的学生id:\n");
scanf("%d",&id);
for(i=0;i<WLW->n;i++)
{
if(id==WLW->st[i].id)
{
printf("the student is exist!\n");
printf("the %d student name is %s\n",i+1,WLW->st[i].name);
printf("the %d student age is %d\n",i+1,WLW->st[i].age);
printf("the %d student id is %d\n",i+1,WLW->st[i].id);
printf("the %d student sex is %s\n",i+1,WLW->st[i].sex);
return i;
}
}
printf("the student is not exist!\n");
return -1;
}
4、定义一个remove_student()函数删除学生信息,这里首先定义一个参数ret,并调用find_student(WLW)查找要删除的学生是否在其中,如果返回值为-1,则进行覆盖,即要删除的学生信息被后面的学生信息所覆盖,另外其中由于于是字符串类型复制时通过使用头文件string.h中的strcpy复制函数从而实现覆盖的功能,然后当前班级学生人数减一:
//删除指定学生
void remove_student(struct class_room *WLW){
int ret,i;
ret=find_student(WLW);
if(ret!=-1)
{
for(i=ret;i<WLW->n-1;i++)
{
strcpy(WLW->st[i].name,WLW->st[i+1].name);//由于是字符串类型复制使用头文件string.h中的strcpy复制函数
WLW->st[i].age=WLW->st[i+1].age;
WLW->st[i].id=WLW->st[i+1].id;
strcpy(WLW->st[i].sex,WLW->st[i+1].sex);
}
WLW->n--;
}
printf("该学生已经删除成功!\n");
}
5、定义一个change_student()函数修改学生信息,因为学生学习有四项,所以这里通过switch语句、goto语句来实现,定义ret参数调用find_student(WLW)查找要删除的学生是否在其中,然后再修改:
//修改学生信息
void change_student(struct class_room *WLW)
{
int ret,choose;
ret=find_student(WLW);
if(ret!=-1)
{
loop1:
printf("修改学生信息的哪一项?\n");
printf("1、姓名\n");
printf("2、年龄\n");
printf("3、id\n");
printf("4、性别\n");
scanf("%d",&choose);
switch(choose)
{
case 1:
printf("请输入新的学生姓名:\n");
scanf("%s",WLW->st[ret].name);//输出的代表首地址,所以不需要&取地址
break;
case 2:
printf("请输入新的学生年龄:\n");
scanf("%d",&WLW->st[ret].age);
break;
case 3:
printf("请输入新的学生id:\n");
scanf("%d",&WLW->st[ret].id);
break;
case 4:
printf("请输入新的学生性别:\n");
scanf("%s",WLW->st[ret].sex);
break;
default:
printf("输出错误,请重新输入!\n");
goto loop1;
}
}
}
以下是完整的程序代码:
/*学生管理系统*/
#include<stdio.h>
#include<string.h>//包含头文件string.h
#define MAX 60//定义MAX最大值为60
struct student{
char name[20];
int age;
int id;
char sex[10];
};
struct class_room{
struct student st[MAX]; //定义多个学生
int n; //当前班级的人数
};
void printf_menu()//打印主菜单函数
{
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");
}
void add_student(struct class_room *WLW)//添加学生信息,其中struct class_room *WLW为结构体指针
{
printf("请输入学生的姓名:\n");
scanf("%s",WLW->st[WLW->n].name); //数组名代表首地址
printf("请输入学生的年龄:\n");
scanf("%d",&WLW->st[WLW->n].age); //取变量的地址
printf("请输入学生的id:\n");
scanf("%d",&WLW->st[WLW->n].id);
printf("请输入学生的性别:\n");
scanf("%s",WLW->st[WLW->n].sex);
WLW->n++;//班级人数加一
}
void show_student(struct class_room *WLW)//显示所有学生信息
{
int i;
for(i=0;i<WLW->n;i++)//WLW->n为当前班级的人数
{
printf("the %d student name is %s\n",i+1,WLW->st[i].name);//第一个学生
printf("the %d student age is %d\n",i+1,WLW->st[i].age);
printf("the %d student id is %d\n",i+1,WLW->st[i].id);
printf("the %d student sex is %s\n",i+1,WLW->st[i].sex);
}
}
int find_student(struct class_room *WLW)//查找指定学生
{
int id,i;
printf("请输入要查找的学生id:\n");
scanf("%d",&id);
for(i=0;i<WLW->n;i++)
{
if(id==WLW->st[i].id)
{
printf("the student is exist!\n");
printf("the %d student name is %s\n",i+1,WLW->st[i].name);
printf("the %d student age is %d\n",i+1,WLW->st[i].age);
printf("the %d student id is %d\n",i+1,WLW->st[i].id);
printf("the %d student sex is %s\n",i+1,WLW->st[i].sex);
return i;
}
}
printf("the student is not exist!\n");
return -1;
}
void remove_student(struct class_room *WLW)//删除指定学生
{
int ret,i;
ret=find_student(WLW);
if(ret!=-1)
{
for(i=ret;i<WLW->n-1;i++)
{
strcpy(WLW->st[i].name,WLW->st[i+1].name);//由于是字符串类型复制使用头文件string.h中的strcpy复制函数
WLW->st[i].age=WLW->st[i+1].age;
WLW->st[i].id=WLW->st[i+1].id;
strcpy(WLW->st[i].sex,WLW->st[i+1].sex);
}
WLW->n--;
}
printf("该学生已经删除成功!\n");
}
void change_student(struct class_room *WLW)//修改学生信息
{
int ret,choose;
ret=find_student(WLW);
if(ret!=-1)
{
loop1:
printf("修改学生信息的哪一项?\n");
printf("1、姓名\n");
printf("2、年龄\n");
printf("3、id\n");
printf("4、性别\n");
scanf("%d",&choose);
switch(choose)
{
case 1:
printf("请输入新的学生姓名:\n");
scanf("%s",WLW->st[ret].name);//输出的代表首地址,所以不需要&取地址
break;
case 2:
printf("请输入新的学生年龄:\n");
scanf("%d",&WLW->st[ret].age);
break;
case 3:
printf("请输入新的学生id:\n");
scanf("%d",&WLW->st[ret].id);
break;
case 4:
printf("请输入新的学生性别:\n");
scanf("%s",WLW->st[ret].sex);
break;
default:
printf("输出错误,请重新输入!\n");
goto loop1;
}
}
}
int main()
{
struct class_room WLW;//定义一个班级为WLW存储学生
WLW.n=0;//初始化,学生人数为0
while(1)//无限循环
{
loop:
printf_menu();//调用主菜单函数输出主菜单
int choose;//定义一个序号
scanf("%d",&choose);
switch(choose)
{
case 1:
add_student(&WLW);//添加学生
break;
case 2:
show_student(&WLW);//显示学生
break;
case 3:
find_student(&WLW);//查询学生
break;
case 4:
remove_student(&WLW);//删除学生
break;
case 5:
change_student(&WLW);//修改学生
break;
case 6:
return 0;//退出程序
default://若输出错误的序号,则跳转至重新输出
printf("输出错误,请重新输入!\n");
goto loop;
}
}
}
运行结果:

添加三个学生的信息,第一个学生:

第二个学生:

第三个学生:

显示所有学生信息:

查询学生信息,例查询id为100的学生:

查询学生信息,例查询一个不存在的学生,查询id为103的学生:

删除学生信息,删除id为102和105的学生,其中id为105的学生不存在:


修改id为100的学生姓名为yyy:

修改后的所有学生信息:

退出程序:

我正在使用i18n从头开始构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在rubyonrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
我想用ruby编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此