一位数组:

 #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语言关于学生管理系统的几种实现方法(一位数组,二维数组,指针,结构体)的更多相关文章

  1. 关于c语言二维数组与指针的个人理解及处理办法。

    相信大家在学习C语言时,对一维数组和指针的理解应该是自信的,但是,我在学习过程中,看到网上一些博文,发现即便是参加工作的一些专业编程人员,突然碰到二维数组和指针的问题时,也可能会遇到难以处理的诡异问题 ...

  2. C语言之二维数组

    二维数组 还是一个数组,只不过数组中得每一个元素又是一个数组 1). 声明语法 类型 数组名[行][列]; 例:  int nums[2][3];//2行3列的二维数组,保存的数据类型是int类型 c ...

  3. C语言指针系列 - 一级指针.一维数组,二级指针,二维数组,指针数组,数组指针,函数指针,指针函数

    1. 数组名 C语言中的数组名是一个特殊的存在, 从本质上来讲, 数组名是一个地址, 我们可以打印一个指针的值,和打印一个数组的值来观察出这个本质: int nArray[10] ={ 0 }; in ...

  4. C语言数组:C语言数组定义、二维数组、动态数组、字符串数组

    1.C语言数组的概念 在<更加优美的C语言输出>一节中我们举了一个例子,是输出一个 4×4 的整数矩阵,代码如下: #include <stdio.h> #include &l ...

  5. C语言二维数组

    上节讲解的数组可以看作是一行连续的数据,只有一个下标,称为一维数组.在实际问题中有很多数据是二维的或多维的,因此C语言允许构造多维数组.多维数组元素有多个下标,以确定它在数组中的位置.本节只介绍二维数 ...

  6. C语言一维数组、二维数组、结构体的初始化

    C语言数组的初始化表示方法 一.C语言一维数组初始化: (1)在定义数组时对数组元素赋以初值.如: static int a[10]={0,1,2,3,4,5,6,7,8,9}; 经过上面的定义和初始 ...

  7. 【C语言入门教程】4.2 二维数组

    C 语言允许使用多维数组,即使用多组小标的数组,二维数组是最常用的多维数组.多维数组在内存中存放数据的顺序与一维数组相同,使用连续的存储单元. 4.2.1 二维数组的一般形式 二维数组的一般声明形式为 ...

  8. C语言中如何将二维数组作为函数的参数传递

    今天写程序的时候要用到二维数组作参数传给一个函数,我发现将二维数组作参数进行传递还不是想象得那么简单里,但是最后我也解决了遇到的问题,所以这篇文章主要介绍如何处理二维数组当作参数传递的情况,希望大家不 ...

  9. c语言二维数组传递

    c语言二维数组传递,目前我总结三种方法,以及纠正一个不能使用的方法 /********************************* * 方法1: 第一维的长度可以不指定 * * 但必须指定第二维 ...

随机推荐

  1. VC++ 判断文件或文件夹是否存在的快捷方法 _access

    _access函数 int _access( const char *path, int mode ); int _waccess( const wchar_t *path, int mode ); ...

  2. mybatis, spring, springmvc

    mybatis配置: mybatis-config.xml <configuration> <!-- 作者MyBatis博客: http://legend2011.blog.51ct ...

  3. 防御病毒邮件得看U-Mail邮件网关

    其实在邮件通讯中,那些病毒.垃圾邮件.钓鱼软件也相当危险,在海量邮件中,你没法确定什么时间.哪一封会发起进攻,攻击的目标都有谁?但是一旦得逞,造成的损失又特别大. 最近美国同行又发现了一个新骗局:美国 ...

  4. python时间函数学习

    格式化当前日期: import time print time.strftime('%Y-%m-%d') 获取一天前的日期: import datetime import time onedayago ...

  5. [题解]USACO 1.3 Wormholes

    Wormholes Farmer John's hobby of conducting high-energy physics experiments on weekends has backfire ...

  6. 使用SVN同步资源后图标样式的详细解读

    项目视图   The Package Explorer view - 已忽略版本控制的文件.可以通过Window → Preferences → Team → Ignored Resources.来忽 ...

  7. Android学习---数据库的增删改查(sqlite CRUD)

    上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...

  8. js的form基础知识点

    在HTML 中,表单是由<form>元素来表示的,而在JavaScript 中,表单对应的则是HTMLForm-Element 类型.HTMLFormElement 继承了HTMLElem ...

  9. 深入理解display属性

    display 属性在网页布局中很常见,但是之前一直不了解他的各个属性的区别,只是简单的使用block.none属性,对于其他属性都不清楚,今天详细的学习和实践display属性的各个方面 定义 di ...

  10. oracle 第一章总结

    sysdba:  即数据库管理员,权限包括:打开数据库服务器.关闭数据库服务器.备份数据库.恢复数据库.日志归档.会话限制.管理功能.创建数据库.sys用户必须用 sysdba身份才能登录,syste ...