用C语言关于学生管理系统的几种实现方法(一位数组,二维数组,指针,结构体)
一位数组:
#include <stdio.h>
#include<string.h>
#define N 5
void luru(float s[],int n);
void shuchu(float s[],int n);
void chaxun(float s[],int n);
void paixu(float a[],int n);
int mimayanzheng();
void caidan(); void main(){
int x,y,k;
float a[N];
x=mimayanzheng();
if(x==){
caidan();
for(k=;k!=;k=y){
printf("请输入选择:");
scanf("%d",&y);
switch(y){
case :luru(a,N);break;
case :shuchu(a,N);break;
case :chaxun(a,N);break;
case :paixu(a,N);break;
case :break;
}
}
} }
int mimayanzheng(){
int i,flat;
char m[]="abc123",x[];
printf("请输入密码:");
for(i=;i<;i++){
flat=;
scanf("%s",&x);
if(!strcmp(m,x)){
flat=;
break;
}
else if(i<)
printf("请重新输入密码:");
}
return flat;
} void caidan(){
printf("+===============================+\n");
printf("+====学=生=成=绩=管=理=系=统====+\n");
printf("+===============================+\n");
printf("+===========1、 录入===========+\n");
printf("+===========2、 输出===========+\n");
printf("+===========3、 查询===========+\n");
printf("+===========4、 排序===========+\n");
printf("+===========5、 退出===========+\n");
printf("+===============================+\n");
} void luru(float s[],int n){
int i;
for(i=;i<n;i++){
printf("请输入第%d个同学的成绩:",i+);
scanf("%f",&s[i]);
}
} void shuchu(float s[],int n){
int i;
for(i=;i<n;i++)
printf("第%d个的同学成绩是:%f \n",i+,s[i]);
} void chaxun(float s[],int n){
int i,flat;
float x;
printf("请输入要查询的成绩:");
scanf("%f",&x);
for(i=,flat=;i<n;i++)
if(x==s[i])
flat =;
if(flat==)
for(i=;i<N;i++){
if(s[i]==x)
printf("有此同学成绩,为第%d个同学的成绩\n",i+);
continue;
}
else
printf("没有此同学成绩\n");
} void paixu(float a[],int n){
int i,j,k;
float temp;
for(j=;j<n-;j++){
k=j;
for(i=j+;i<n;i++)
if(a[i]<a[k])
k=i;
if(k!=j){
temp=a[k];
a[k]=a[j];
a[j]=temp;
}
}
printf("从小到大的排序是:");
for(i=;i<N;i++)
printf("%f ",a[i]);
printf("\n");
}
二维数组:
#include <stdio.h>
#include<string.h>
#define a 2
#define b 3 void luru(float s[][b]);
void shuchu(float s[][b]);
void chaxun(float s[][b]);
void paixu(float m[][b]);
int mimayanzheng();
void caidan(); void main(){
int x,y,k;
float z[a][b];
x=mimayanzheng();
if(x==){
caidan();
for(k=;k!=;k=y){
printf("请输入选择:");
scanf("%d",&y);
switch(y){
case :luru(z);break;
case :shuchu(z);break;
case :chaxun(z);break;
case :paixu(z);break;
case :break;
}
}
} }
int mimayanzheng(){
int i,flat;
char m[]="abc123",x[];
printf("请输入密码:");
for(i=;i<;i++){
flat=;
scanf("%s",&x);
if(!strcmp(m,x)){
flat=;
break;
}
else if(i<)
printf("请重新输入密码:");
}
return flat;
} void caidan(){
printf("+===============================+\n");
printf("+====学=生=成=绩=管=理=系=统====+\n");
printf("+===============================+\n");
printf("+===========1、 录入===========+\n");
printf("+===========2、 输出===========+\n");
printf("+===========3、 查询===========+\n");
printf("+===========4、 排序===========+\n");
printf("+===========5、 退出===========+\n");
printf("+===============================+\n");
} void luru(float s[a][b]){
int i,j;
for(j=;j<a;j++){
for(i=;i<b;i++){
printf("请输入第%d个同学的第%d科成绩:",j+,i+);
scanf("%f",&s[j][i]);
}
}
} void shuchu(float s[a][b]){
int i,j;
for(j=;j<a;j++){
for(i=;i<b;i++){
printf("第%d个同学的第%d科成绩是%f:\n",j+,i+,s[j][i]);
}
}
} void chaxun(float s[a][b]){
int i,j,flat;
float x;
printf("请输入要查询的成绩:");
scanf("%f",&x);
for(j=;j<a;j++){
for(i=,flat=;i<b;i++)
if(x==s[j][i])
flat =;
if(flat==){
for(j=;j<a;j++){
for(i=;i<b;i++){
if(s[j][i]==x)
printf("有此同学成绩,为第%d个同学的第%d科成绩\n",j+,i+);
continue;
}
}
}
else
printf("没有此同学成绩\n");
}
} void paixu(float m[a][b]){
int i,j,k,p;
float temp;
for(p=;p<a;p++){
for(j=;j<b-;j++){
k=j;
for(i=j+;i<b;i++)
if(m[p][i]<m[p][k])
k=i;
if(k!=j){
temp=m[p][k];
m[p][k]=m[p][j];
m[p][j]=temp;
}
}
}
printf("从小到大的排序是:\n");
for(j=;j<a;j++){
for(i=;i<b;i++)
printf("%f ",m[j][i]);
printf("\n");
}
printf("\n");
}
指针:
#include <stdio.h>
#include<string.h>
#define N 5
void luru(double *s,int n);
void shuchu(double *s,int n);
void chaxun(double *s,int n);
void paixu(double *a,int n);
int mimayanzheng();
void caidan(); void main(){
int x,y,k;
double b[N];
double *a;
a=b;
x=mimayanzheng();
if(x==){
caidan();
for(k=;k!=;k=y){
printf("请输入选择:");
scanf("%d",&y);
switch(y){
case :luru(a,N);break;
case :shuchu(a,N);break;
case :chaxun(a,N);break;
case :paixu(a,N);break;
case :break;
}
}
} }
int mimayanzheng(){
int i,flat;
char m[]="abc123",x[];
printf("请输入密码:");
for(i=;i<;i++){
flat=;
scanf("%s",&x);
if(!strcmp(m,x)){
flat=;
break;
}
else if(i<)
printf("请重新输入密码:");
}
return flat;
} void caidan(){
printf("+===============================+\n");
printf("+====学=生=成=绩=管=理=系=统====+\n");
printf("+===============================+\n");
printf("+===========1、 录入===========+\n");
printf("+===========2、 输出===========+\n");
printf("+===========3、 查询===========+\n");
printf("+===========4、 排序===========+\n");
printf("+===========5、 退出===========+\n");
printf("+===============================+\n");
} void luru(double * s,int n){
int i;
double k;
for(i=;i<n;i++){
printf("请输入第%d个同学的成绩:",i+);
scanf("%lf",&k);
* (s+i)=k;
}
} void shuchu(double *s,int n){
int i;
for(i=;i<n;i++)
printf("第%d个的同学成绩是:%lf \n",i+,*(s+i));
} void chaxun(double *s,int n){
int i,flat;
double x;
printf("请输入要查询的成绩:");
scanf("%f",&x);
for(i=,flat=;i<n;i++)
if(x==*(s+i))
flat =;
if(flat==)
for(i=;i<n;i++){
if(*(s+i)==x)
printf("有此同学成绩,为第%d个同学的成绩\n",i+);
continue;
}
else
printf("没有此同学成绩\n");
} void paixu(double *a,int n){
int i,j,k;
double temp;
for(j=;j<n-;j++){
k=j;
for(i=j+;i<n;i++)
if(*(a+i)<*(a+k))
k=i;
if(k!=j){
temp=*(a+k);
*(a+k)=*(a+j);
*(a+j)=temp;
}
}
printf("从小到大的排序是:");
for(i=;i<N;i++)
printf("%f ",*(a+i));
printf("\n");
}
结构体:
#include <stdio.h>
#include<string.h>
#define N 5
void luru(struct xitong student[],int n);
void shuchu(struct xitong student[],int n);
void chaxun(struct xitong student[],int n);
void paixu(struct xitong student[],int n);
int mimayanzheng();
void caidan();
struct xitong{
char xingming[];
int xuehao;
float yuwen;
float shuxue;
float yingyu;
}; void main(){
int x,y,k;
struct xitong student [N];
x=mimayanzheng();
if(x==){
caidan();
for(k=;k!=;k=y){
printf("请输入选择:");
scanf("%d",&y);
switch(y){
case :luru(student,N);break;
case :shuchu(student,N);break;
case :chaxun(student,N);break;
//case 4 :paixu(student,N);break;
case :break;
}
}
} }
int mimayanzheng(){
int i,flat;
char m[]="abc123",x[];
printf("请输入密码:");
for(i=;i<;i++){
flat=;
scanf("%s",&x);
if(!strcmp(m,x)){
flat=;
break;
}
else if(i<)
printf("请重新输入密码:");
}
return flat;
} void caidan(){
printf("+===============================+\n");
printf("+====学=生=成=绩=管=理=系=统====+\n");
printf("+===============================+\n");
printf("+===========1、 录入===========+\n");
printf("+===========2、 输出===========+\n");
printf("+===========3、 查询===========+\n");
printf("+===========4、 排序===========+\n");
printf("+===========5、 退出===========+\n");
printf("+===============================+\n");
} void luru(struct xitong student[],int n){
int i;
for(i=;i<n;i++){
printf("请输入第%d个同学的信息(姓名,学号,语文,数学,英语):",i+);
scanf("%s %d %f %f %f",&student[i].xingming,&student[i].xuehao,&student[i].yuwen,&student[i].shuxue,&student[i].yingyu);
}
} void shuchu(struct xitong student[],int n){
int i;
for(i=;i<n;i++)
printf("第%d个的同学信息是: \n姓名:%s\n学号:%d\n语文:%f\n数学:%f\n英语:%f\n",i+,student[i].xingming,student[i].xuehao,student[i].yuwen,student[i].shuxue,student[i].yingyu);
} void chaxun(struct xitong student[],int n){
int i,flat;
float x;
printf("请输入要查询的成绩:");
scanf("%f",&x);
for(i=,flat=;i<n;i++)
if(x==student[i].yuwen||x==student[i].shuxue||x==student[i].yingyu)
flat =;
if(flat==)
for(i=;i<N;i++){
if(x==student[i].yuwen||x==student[i].shuxue||x==student[i].yingyu)
printf("有此同学成绩,为%s同学的成绩\n",student[i].xingming);
continue;
}
else
printf("没有此同学成绩\n");
}
用C语言关于学生管理系统的几种实现方法(一位数组,二维数组,指针,结构体)的更多相关文章
- 关于c语言二维数组与指针的个人理解及处理办法。
相信大家在学习C语言时,对一维数组和指针的理解应该是自信的,但是,我在学习过程中,看到网上一些博文,发现即便是参加工作的一些专业编程人员,突然碰到二维数组和指针的问题时,也可能会遇到难以处理的诡异问题 ...
- C语言之二维数组
二维数组 还是一个数组,只不过数组中得每一个元素又是一个数组 1). 声明语法 类型 数组名[行][列]; 例: int nums[2][3];//2行3列的二维数组,保存的数据类型是int类型 c ...
- C语言指针系列 - 一级指针.一维数组,二级指针,二维数组,指针数组,数组指针,函数指针,指针函数
1. 数组名 C语言中的数组名是一个特殊的存在, 从本质上来讲, 数组名是一个地址, 我们可以打印一个指针的值,和打印一个数组的值来观察出这个本质: int nArray[10] ={ 0 }; in ...
- C语言数组:C语言数组定义、二维数组、动态数组、字符串数组
1.C语言数组的概念 在<更加优美的C语言输出>一节中我们举了一个例子,是输出一个 4×4 的整数矩阵,代码如下: #include <stdio.h> #include &l ...
- C语言二维数组
上节讲解的数组可以看作是一行连续的数据,只有一个下标,称为一维数组.在实际问题中有很多数据是二维的或多维的,因此C语言允许构造多维数组.多维数组元素有多个下标,以确定它在数组中的位置.本节只介绍二维数 ...
- C语言一维数组、二维数组、结构体的初始化
C语言数组的初始化表示方法 一.C语言一维数组初始化: (1)在定义数组时对数组元素赋以初值.如: static int a[10]={0,1,2,3,4,5,6,7,8,9}; 经过上面的定义和初始 ...
- 【C语言入门教程】4.2 二维数组
C 语言允许使用多维数组,即使用多组小标的数组,二维数组是最常用的多维数组.多维数组在内存中存放数据的顺序与一维数组相同,使用连续的存储单元. 4.2.1 二维数组的一般形式 二维数组的一般声明形式为 ...
- C语言中如何将二维数组作为函数的参数传递
今天写程序的时候要用到二维数组作参数传给一个函数,我发现将二维数组作参数进行传递还不是想象得那么简单里,但是最后我也解决了遇到的问题,所以这篇文章主要介绍如何处理二维数组当作参数传递的情况,希望大家不 ...
- c语言二维数组传递
c语言二维数组传递,目前我总结三种方法,以及纠正一个不能使用的方法 /********************************* * 方法1: 第一维的长度可以不指定 * * 但必须指定第二维 ...
随机推荐
- 关于Onvif的event
昨天又仔细研究了一下camera的alarm功能,发现原来很简单,首先订阅一下,即create,拿到订阅号后直接pull,一旦收到信息就再次用订阅号pull.参考http://www.doc88.co ...
- web前端之性能优化
作为一个前端工作人员,而且只会写点HTML5和CSS3的“假”前端工程师,为了能更好地理解一下前端的花花世界,最近拜读了<高性能网站建设指南>一书,对作者提出的前端性能优化的14个规则获益 ...
- 将sqlserve数据绑定到dataGridView中及一些操作
一:将数据绑定到dataGridView控件上. string sqlconn = "server=.;database=student;integrated security=true&q ...
- Apache伪静态在网站目录没有反斜杠后自动添加反斜杠
第一步:确认网站开启REWRITE规则 一般有两种情况: i.apache安装的时候已经包含rewrite功能 ii.后续配置的时候新添加mod_rewrite.so.这种情况需要在httpd.con ...
- 9×9扫雷游戏代码-C写的
#include <stdio.h> #include <stdlib.h> //画棋盘 a雷表 b周围雷数表 c打开表 ][],][],][]) { ,j=; ;i<; ...
- WizNote for linux installation
源一:没有用处 官网链接http://www.wiznote.com/download-wiznote-for-Linux. 源二:提供了源及安装方法 Fedora 中文社区软件源,具体位置在这里. ...
- miniui中常用的状态显示方式
1.查询sys_code表得到对应的状态 考生状态:<input class="mini-combobox" style="" textField=&qu ...
- db2 常用函数
语法:VALUE(EXPRESSION1,EXPRESSION2) VALUE函数是用返回一个非空的值,当其第一个参数非空,直接返回该参数的值,如果第一个参数为空,则返回第一个参数的值. eg: -- ...
- 第一次将内容添加到azure event hubs
由于每秒数据吞吐量巨大,需要将实时数据存到event hubs,再由event hubs定时定量保存到document DB. event hubs的介绍详见微软官页:https://azure.mi ...
- pandas中将timestamp转为datetime
参考自:http://stackoverflow.com/questions/35312981/using-pandas-to-datetime-with-timestamps 在pandas Dat ...