用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: 第一维的长度可以不指定 * * 但必须指定第二维 ...
随机推荐
- unity3d 孤岛求生基础案例
第二个案例,此案例主要实现了第一人称控制器,把移动从世界坐标系转化到人物平面坐标系,通过碰撞器,触发器,光线透射触发器实现交互.实现UI texture记录收集信息,ui texture是更新内容对应 ...
- DIOCP之编写第一个应用程序(三)
Client 设计功能如下: 1.建立与服务器连接 2.请求连接时,加密密码,采用Base64编码 3.定时发送心跳告诉服务器在线(长连接,用于接收推送信息) 4.进行相关的数据处理与交互 第一步:创 ...
- eclipse中outline中图标的含义
outline: 实心的代表方法 空心的代表属性 绿色的圆表示公有public 黄色的菱形表示保护protect 红色的方形表示私有private 蓝色的三角表示default 图形后加字母S代表该属 ...
- 微信小程序 wx.getUserInfo 解密 C# 代码
花了6小时,弄出来的代码.网上的是PHP代码 public static string DecodeUserInfo(string raw, string signature,string encry ...
- [整理]一个有关Latch(锁存器)的有趣问题
起源 今天诳论坛,突然发现了一个有关latch的问题,由于对D Flip-Flop和Latch还有些疑问,就点击了进去,一看果然有些意思,也挺有学习意义的,于是本文就诞生了.喊出口号~Just not ...
- Oracle中的正则表达式
检查约束 --密码的长度必须在3-6 --年龄必须在1-120 --性别只能是男或女 --电话号码必须满足电话的格式: 手机格式,座机格式 drop table test; select * from ...
- 附加数据库失败,sql2008,断电数据库日志受损
附加数据库失败,提示:无法在数据库 'DBNAME' (数据库 ID 为 7)的页 (1:210288) 上重做事务 ID (0:0) 的日志记录或者在重做数据库 'DBNAME' 的日志中记录的操作 ...
- poj 1236 Network of Schools(连通图)
题目链接:http://poj.org/problem?id=1236 题目大意:有一些学校,学校之间可以进行收发邮件,给出学校的相互关系,问:1.至少 要向这些学校发送多少份才能使所有的学校都能获得 ...
- 【经验】Maven Tomcat8+ 实现自动化部署
1.配置tomcat-users.xml 首先在Tomcat里配置deploy的用户(tomcat根目录/conf/tomcat-users.xml): <role rolename=" ...
- .net学习笔记--文件读写的几种方式
在.net中有很多有用的类库来读写硬盘上的文件 一般比较常用的有: File:1.什么时候使用:当读写件大小不大,同时可以一次性进行读写操作的时候使用 2.不同的方式可以读写文件类型不 ...