一位数组:

 #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. 从零开始学 ios 的一些建议 摘自http://www.cocoachina.com/ios/20150826/13151.html

    我是一只小菜鸟,今天在cocoaChina 看到一篇关于初学者,也就是零基础的童鞋的一些建议,感觉写的好好. 我觉得,学习真的是很累,但是,你要记得一句话,,世界上最最可怕的两个字是认真.共勉! 事情 ...

  2. spring整合freemarker

    一.配置maven <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www ...

  3. wpf 遮住输入法 问题

    可以参考这个代码   http://www.cnblogs.com/Leaco/p/3164394.html 当你发现没用的时候 可以改这句代码  var hwnd = ((HwndSource)Pr ...

  4. ios调用系统相册、相机 显示中文标题、本地化多语言支持

    因为调用系统相册.相机需要显示中文,所以搞了半天才知道是在Project->info->Custom ios Target Properties 添加 Localizations 并加入C ...

  5. 新版react踩坑总结

    使用es6语法与原本es5语法几个有区别的地方 1.React.creatClass与React.Component var Component = React.createClass({ rende ...

  6. mysql远程连接命令(转)

    一.MySQL 连接本地数据库,用户名为"root",密码"123"(注意:"-p"和"123" 之间不能有空格) C: ...

  7. POJ 2528 Mayor's posters (线段树)

    题目链接:http://poj.org/problem?id=2528 题目大意:有一个很上的面板, 往上面贴海报, 问最后最多有多少个海报没有被完全覆盖 解题思路:将贴海报倒着想, 对于每一张海报只 ...

  8. java中trim()函数是什么

    trim() 去除字符串前缀和后缀空格 文件名:Test.java ,编译通过 public class Test {     public static void main(String args[ ...

  9. easy ui 框架

    Easy UI 准备工作(搭建) 1.在WebRoot 的目录下创建js 文件夹,在文件夹中倒入一下两个包 Jquery.easyui.min.js jquery.min.js 2.在WebRoot ...

  10. 实用脚本----Linux下Jdk和Tomcat自动安装shell脚本总结

    系统环境为:ubuntu 14.04 一.JDK 自动安装脚本 jdk自动安装bash shell脚本,截止今天(2014/10/15)亲测可用: sudo su #切换到root权限 mkdir / ...