學生管理系統的幾種實現方法(一位數組,二維數組,指針,結構體)

来源:http://www.cnblogs.com/yjh123/archive/2016/05/31/5546414.html
-Advertisement-
Play Games

一位數組: #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 p ...


一位數組:

#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==1){
        caidan();
        for(k=0;k!=5;k=y){
            printf("請輸入選擇:");
            scanf("%d",&y);
            switch(y){
                case 1 :luru(a,N);break;
                case 2 :shuchu(a,N);break;
                case 3 :chaxun(a,N);break;
                case 4 :paixu(a,N);break;
                case 5 :break;
            }
        }
    }

   

}
int mimayanzheng(){
    int i,flat;
    char m[7]="abc123",x[10];
    printf("請輸入密碼:");
    for(i=0;i<3;i++){
        flat=0;
        scanf("%s",&x);
        if(!strcmp(m,x)){
            flat=1;
            break;
        }
        else if(i<2)
            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=0;i<n;i++){
        printf("請輸入第%d個同學的成績:",i+1);
        scanf("%f",&s[i]);
    }
}

void shuchu(float s[],int n){
    int i;
    for(i=0;i<n;i++)
    printf("第%d個的同學成績是:%f \n",i+1,s[i]);
}

void chaxun(float s[],int n){
    int i,flat;
    float x;
    printf("請輸入要查詢的成績:");
    scanf("%f",&x);
    for(i=0,flat=0;i<n;i++)
        if(x==s[i])
            flat =1;
    if(flat==1)
        for(i=0;i<N;i++){
            if(s[i]==x)
                printf("有此同學成績,為第%d個同學的成績\n",i+1);
            continue;
        }
    else
        printf("沒有此同學成績\n");
}

void paixu(float a[],int n){
    int i,j,k;
    float temp;
    for(j=0;j<n-1;j++){
        k=j;
        for(i=j+1;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=0;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==1){
        caidan();
        for(k=0;k!=5;k=y){
            printf("請輸入選擇:");
            scanf("%d",&y);
            switch(y){
                case 1 :luru(z);break;
                case 2 :shuchu(z);break;
                case 3 :chaxun(z);break;
                case 4 :paixu(z);break;
                case 5 :break;
            }
        }
    }

   

}
int mimayanzheng(){
    int i,flat;
    char m[7]="abc123",x[10];
    printf("請輸入密碼:");
    for(i=0;i<3;i++){
        flat=0;
        scanf("%s",&x);
        if(!strcmp(m,x)){
            flat=1;
            break;
        }
        else if(i<2)
            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=0;j<a;j++){
        for(i=0;i<b;i++){
            printf("請輸入第%d個同學的第%d科成績:",j+1,i+1);
            scanf("%f",&s[j][i]);
        }
    }
}

void shuchu(float s[a][b]){
    int i,j;
    for(j=0;j<a;j++){
        for(i=0;i<b;i++){
            printf("第%d個同學的第%d科成績是%f:\n",j+1,i+1,s[j][i]);
        }
    }
}

void chaxun(float s[a][b]){
    int i,j,flat;
    float x;
    printf("請輸入要查詢的成績:");
    scanf("%f",&x);
    for(j=0;j<a;j++){
        for(i=0,flat=0;i<b;i++)
            if(x==s[j][i])
                flat =1;
    if(flat==1){
        for(j=0;j<a;j++){
            for(i=0;i<b;i++){
                if(s[j][i]==x)
                    printf("有此同學成績,為第%d個同學的第%d科成績\n",j+1,i+1);
            continue;
        }
        }
    }
    else
        printf("沒有此同學成績\n");
    }
}

void paixu(float m[a][b]){
    int i,j,k,p;
    float temp;
    for(p=0;p<a;p++){
            for(j=0;j<b-1;j++){
                k=j;
                for(i=j+1;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=0;j<a;j++){
        for(i=0;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==1){
        caidan();
        for(k=0;k!=5;k=y){
            printf("請輸入選擇:");
            scanf("%d",&y);
            switch(y){
                case 1 :luru(a,N);break;
                case 2 :shuchu(a,N);break;
                case 3 :chaxun(a,N);break;
                case 4 :paixu(a,N);break;
                case 5 :break;
            }
        }
    }

   

}
int mimayanzheng(){
    int i,flat;
    char m[7]="abc123",x[10];
    printf("請輸入密碼:");
    for(i=0;i<3;i++){
        flat=0;
        scanf("%s",&x);
        if(!strcmp(m,x)){
            flat=1;
            break;
        }
        else if(i<2)
            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=0;i<n;i++){
        printf("請輸入第%d個同學的成績:",i+1);
        scanf("%lf",&k);
        * (s+i)=k;
    }
}

void shuchu(double *s,int n){
    int i;
    for(i=0;i<n;i++)
    printf("第%d個的同學成績是:%lf \n",i+1,*(s+i));
}

void chaxun(double *s,int n){
    int i,flat;
    double x;
    printf("請輸入要查詢的成績:");
    scanf("%f",&x);
    for(i=0,flat=0;i<n;i++)
        if(x==*(s+i))
            flat =1;
    if(flat==1)
        for(i=0;i<n;i++){
            if(*(s+i)==x)
                printf("有此同學成績,為第%d個同學的成績\n",i+1);
            continue;
        }
    else
        printf("沒有此同學成績\n");
}

void paixu(double *a,int n){
    int i,j,k;
    double temp;
    for(j=0;j<n-1;j++){
        k=j;
        for(i=j+1;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=0;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[10];
    int xuehao;
    float yuwen;
    float shuxue;
    float yingyu;
};

 

 


void main(){
    int x,y,k;
    struct xitong student [N];
    x=mimayanzheng();
    if(x==1){
        caidan();
        for(k=0;k!=5;k=y){
            printf("請輸入選擇:");
            scanf("%d",&y);
            switch(y){
                case 1 :luru(student,N);break;
                case 2 :shuchu(student,N);break;
                case 3 :chaxun(student,N);break;
                //case 4 :paixu(student,N);break;
                case 5 :break;
            }
        }
    }

   

}
int mimayanzheng(){
    int i,flat;
    char m[7]="abc123",x[10];
    printf("請輸入密碼:");
    for(i=0;i<3;i++){
        flat=0;
        scanf("%s",&x);
        if(!strcmp(m,x)){
            flat=1;
            break;
        }
        else if(i<2)
            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=0;i<n;i++){
        printf("請輸入第%d個同學的信息(姓名,學號,語文,數學,英語):",i+1);
        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=0;i<n;i++)
    printf("第%d個的同學信息是: \n姓名:%s\n學號:%d\n語文:%f\n數學:%f\n英語:%f\n",i+1,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=0,flat=0;i<n;i++)
        if(x==student[i].yuwen||x==student[i].shuxue||x==student[i].yingyu)
            flat =1;
    if(flat==1)
        for(i=0;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");
}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • python中至少包括兩種錯誤:語法錯誤(syntax errors)和異常(exceptions)。 1.語法錯誤 語法錯誤,也被稱作解析錯誤 語法分析器指出錯誤行,並且在檢測到錯誤的位置前面顯示一個小“箭頭”。 錯誤是由箭頭前面的標記引起的(或者至少是這麼檢測的)。錯誤會輸出文件名和行號,所以如 ...
  • Application是所有應用程式類的基類,接下來瞭解一下它的源碼。yii2\base\Application.php。 未完待續。 ...
  • Java讀文件 Java寫文件 ...
  • for($i=0;$i<5;$i++){ $rand .= dechex(rand(1,15)); // 隨機數16進位 1-F 生成5個 } $im = imagecreatetruecolor(100,30); // 驗證碼的大小(畫板) $bg = imagecolorallocate($im ...
  • 一、本節用到的基礎知識 1.逐行讀取文件 2.解析json字元串 Python中有一些內置模塊可以非常便捷地將json字元串轉換為Python對象。比如json模塊中的json.relaods()方法可以將json字元串解析為相應的字典。 運行結果: 3.列表生成式 詳見:http://www.cn ...
  • 最近做spring開發,個人認為,Controller和客戶端js通訊時傳遞的參數類 只使用某幾個方法,為了減少對其他功能的影響,想把參數類定義為Controller類的 嵌套類(內部類)。但是實踐發現不行。 系統會報錯: Servlet.service() for servlet [kingkoo ...
  • 目前比較流行的驗證做法:前端jquery-form-validate + 後端hibernate-validate 在pom中添加相關jar: spring mvc中配置: 配置錯誤信息:(當然也可以直接寫在javabean中) entity(setter getter 略): controller ...
  • 迴圈、控制語句 for: 迴圈、控制語句 while: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...