C程式範例(2)——學生管理系統”鏈表“實現

来源:http://www.cnblogs.com/yjds/archive/2016/09/20/5887996.html
-Advertisement-
Play Games

1.對於學生管理系統,能夠實現的方法有許多,但是今天我們用鏈表的方法來實現。雖然初學者很可能看不懂,但是不要緊,這是要在整體的系統的學習完C語言之後,我才編寫出的程式。所以大家不必要擔心。在這裡與大家分享我的學生管理系統的鏈表的實現過程。 2.希望與大家共同努力,共同上進。 長風破浪會有時,直掛雲帆 ...


1.對於學生管理系統,能夠實現的方法有許多,但是今天我們用鏈表的方法來實現。雖然初學者很可能看不懂,但是不要緊,這是要在整體的系統的學習完C語言之後,我才編寫出的程式。所以大家不必要擔心。在這裡與大家分享我的學生管理系統的鏈表的實現過程。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<conio.h>
struct student 
{
    char bianhao[16];
    char name[16];
    struct student *next;
};
struct student *creat()//創建鏈表
{
    struct student *head,*p,*end;
    head=p=end=(struct student*)malloc(sizeof(struct student));
    printf("請輸入學生的編號:\n");
    scanf("%s",p->bianhao);
    while(strcmp(p->bianhao,"0")!=0)
    {
        end=p;
        printf("請輸入學生的姓名\n");
        scanf("%s",p->name);
        p=(struct student *)malloc(sizeof(struct student));
        end->next=p;
        printf("請輸入學生的編號\n");
        scanf("%s",p->bianhao);
    }
    end->next=NULL;
}
void save(struct student *head)//將鏈表保存為文件形式
{   
    FILE *fp;
    struct student *p;
    char filename[20];
    int ch;
    printf("請輸入要保存的文件名\n");
    scanf("%s",filename);
    if(fp=fopen(filename,"r")!=NULL)
    {
        printf("該文件已經存在,是否覆蓋?\n");
        printf("1-覆蓋,2-不覆蓋\n");
        scanf("%d",&ch);
        if(ch!=1)
        {
            printf("請重新輸入要保存的文件名\n");
            scanf("%s",filename);
        }
    }
    if(fp=fopen(filename,"w")==NULL)
    {
        printf("創建文件失敗\n");
    }
    p=head;
    while(p!=NULL)
    {
        fprintf(fp,"%s\n",p->bianhao);
        fprintf(fp,"%s\n",p->name);
        p=p->next;
    }
    fputs("over",fp);
    printf("文件保存成功\n");
    fclose(fp);
}
void output(struct student *head)//輸出鏈表
{
    struct student *p;
    p=head;
    if(p==NULL)
    {
        printf("沒有創建任何記錄\n");
    }
    while(p!=NULL)
    {
        printf("%s",p->bianhao);
        printf("%s",p->name);
        p=p->next;
    }
}
struct student *openfile()//打開文件,即新創建連表讀取鏈表文件
{
    struct student *head,*p,*f;
    FILE *fp;
    char filename[20];
    int ch;
    printf("請輸入想要打開的文件名\n");
    scanf("%s",filename);
    if(fp=fopen(filename,"r")==NULL)
    {
        printf("打開文件失敗\n");
        printf("1-請重新輸入文件名\n2-退出");
        scanf("%d",&ch);
        if(ch==1)
            scanf("%s",filename);
        else if(ch==2)
            return NULL;
    }
    head=p=f=(struct student *)malloc(sizeof(struct student));
    fscanf(fp,"%s%s",p->bianhao,p->name);
    while(!feof(fp))
    {
        p=(struct student *)malloc(sizeof(struct student));
        f->next=p;//用以節點的鏈接,是f節點的下一個是p節點,從而就將p,與f聯繫起來了
        fscanf(fp,"%s%s",p->bianhao,p->name);
        if(strcmp(p->bianhao,"over")==0)
        {
            f->next=NULL;
            printf("文件打開成功\n");
        }
        f=p;
    }
}
void sort_hao(struct student *head)//按照標號排序
{
    struct student *p,*f,*t;
    char ch[100];
    int i;
    p=f=t=head;
    if(head==NULL)
    {
        printf("沒有打開任何文件\n");
    }
    for(p=head;p->next!=NULL;p=p->next)
    {
        for(t=head;f=t->next;t=t->next,f=f->next)
        {
            if(strcmp(t->bianhao,f->bianhao)>0)
            {
                strcpy(ch,t->bianhao);
                strcpy(t->bianhao,f->bianhao);
                strcpy(f->bianhao,ch);

                strcpy(ch,t->name);
                strcpy(t->name,f->name);
                strcpy(f->name,ch);
            }
        }
    }
    printf("排序完成\n");
}
void sort_name(struct student *head)//按照姓名排序
{
    struct student *p,*f,*t;
    char ch[100];
    int i;
    p=f=head=t;
    if(head=NULL)
    {
        printf("文件未能打開\n");
    }
    for(p=head;p->next!=NULL;p=p->next)
    {
        for(t=head;f=t->next!=NULL;t=t->next,f=f->next)
        {
            if(strcmp(t->name,f->name)>0)
            {
                strcpy(ch,t->bianhao);
                strcpy(t->bianhao,f->bianhao);
                strcpy(f->bianhao,ch);

                strcpy(ch,t->name);
                strcpy(t->name,f->name);
                strcpy(f->name,ch);
            }
        }
    }
    printf("完成排序\n");
}
void search(struct student *head)//查詢
{
    struct student *p;
    char str[20];
    int i,j=0;
    p=head;
    if(head==NULL)
    {
        printf("沒有打開任何文件\n");
    }
    printf("1-按照編號查詢\n2-按照姓名查詢\n");
    scanf("%d",&i);
    if(i=1)
    {
        printf("請輸入學生的編號\n");
    }
    else
    {
        printf("請輸入學生的姓名\n");
    }
    scanf("%s",str);
    while(p!=NULL)
    {
        if(i==1)
        {
            if(strcmp(p->bianhao,str)==0)
            {
                printf("編號:%s\n姓名:%s\n",p->bianhao,p->name);
                j=1;
                break;
            }
        }
        if(i==2)
        {
            if(strcmp(p->name,str)==0)
            {
                printf("編號:%s\n姓名:%s\n",p->name,p->name);
                j=1;
            }
        }
        p=p->next;
    }
    if(j==0)
    {
        printf("查找完畢,沒有找到任何結果\n");
    }
}
struct student *add(struct student *head)//添加學生的信息
{
    struct student *p,*e,*f,*h;
    if(head==NULL)
    {
        printf("打開文件失敗\n");
    }
    h=e=f=head;
    p=(struct student *)malloc(sizeof(struct student));//新添加節點,即新添加記錄
    printf("編號:\n");
    scanf("%s",p->bianhao);
    printf("姓名:\n");
    scanf("%s",p->name);
    if(strcmp(f->bianhao,p->bianhao)>0)
    {
        p->next=f;
        h=p;
        printf("添加成功\n");
    }
    if(f->next=NULL)
    {
        f->next=p;
        p->next=NULL;
        printf("添加成功\n");
    }
    while(f->next!=NULL)
    {
        if(f->next==NULL)
        {
            f->next=p;
            p->next=NULL;
            printf("添加成功\n");
        }
    }
}
struct student *delete_mem(struct student *head)//刪除個人信息
{
    struct student *p,*e;
    char str[20];
    if(head==NULL)
    {
        printf("未能打開任何文件\n");
    }
    p=e=head;
    printf("請輸入要刪除的編號\n");
    scanf("%s",str);
    if(strcmp(p->bianhao,str)==0)
    {
        head=head->next;
        printf("刪除成功\n");
    }
    p=p->next;
    while(p!=NULL)
    {
        if(strcmp(p->bianhao,str)==0)
        {
            if(p->next!=NULL)
                e->next=p->next;
            if(p->next==NULL)
                e->next=NULL;
            printf("刪除成功\n");
        }
        p=p->next;
        e=e->next;
    }
    printf("搜索完畢,未能找到結果\n");
}
struct student *change(struct student *head)//修改學生的信息
{
    struct student *p;
    char str[20];
    if(head==NULL)
    {
        printf("未能打開任何文件\n");
    }
    p=head;
    printf("請輸入要修改的學生編號\n");
    scanf("%s",p->bianhao);
    while(p!=NULL)
    {
        if(strcmp(p->bianhao,str)==0)
        {
            printf("編號:%s\n姓名:%s\n",p->bianhao,p->name);
            printf("請按照提示操作\n");
            printf("編號\n");
            scanf("%s",p->bianhao);
            printf("姓名\n");
            scanf("%s",p->name);
        }
        p=p->next;
    }
    printf("未能找到記錄\n");
}
void mima()//密碼的加密
{
    FILE *fp;
    char mima1[20],mima2[20];
    int i=0;
    if(fp=fopen("mima","r")==NULL)
    {
        printf("密碼尚未創建\n");
        do
        {
            printf("請輸入密碼\n");
            scanf("%s",mima1);
            printf("請在此輸入密碼\n");
            scanf("%s",mima2);
            if(strcmp(mima1,mima2)!=0)
            {
                printf("兩次輸入的密碼不同,請重新輸入\n");
                i=1;
            }
            else
                break;
        }while(i);
        fp=fopen("mima","w");
        fprintf(fp,"%s",mima1);
        printf("密碼試製成功\n");
        fclose(fp);
    }
    else
        printf("密碼以創建\n");
}
void delete_doc()//文件的刪除操作
{
    FILE *fp;
    char mima1[20],mima2[20],filename[20];
    printf("請輸入初始密碼\n");
    scanf("%s",mima1);
    fp=fopen("mima1","r");
    fscanf(fp,"%s",mima2);
    if(strcmp(mima1,mima2)==0)
    {
        printf("請輸入要刪除的文件名\n");
        scanf("%s",filename);
        if(remove(filename)==0)//remove函數的應用?
        {
            printf("刪除成功\n");
        }
        else
        {
            printf("刪除失敗");
        }
    }
    else
        printf("密碼錯誤\n");
}
void output_use()
{
    printf("使用方法如下\n");
    printf("1-編輯個人信息之後需要保存,否則再次啟動時會覆蓋\n");
    printf("2-保存信息後,若要在原文件中添加,則需要先打開文件功能,然後再添加記錄,然後再保存\n");
    printf("3-除了新建文件之外,進行其他功能,先打開文件才能繼續\n");
    printf("4-編輯個人信息時,以學號0作為結束,故學生學號是沒有為0的\n");
    printf("5-由於本系統的缺陷,故在保存前需要保存一個學生的信息\n");
}
void output_view()//功能表
{
    printf("==========================\n");
    printf("0-使用說明\n");
    printf("1-編輯學生的信息\n");
    printf("2-保存學生的信息\n");
    printf("3-顯示學生的信息\n");
    printf("4-打開記錄\n");
    printf("5-將記錄排序\n");
    printf("6-查詢記錄\n");
    printf("7-添加記錄\n");
    printf("8-刪除記錄\n");
    printf("9-修改記錄\n");
    printf("a-設置密碼\n");
    printf("b-刪除文件\n");
    printf("==========================\n");
}
void main()//主函數
{
    struct student *head=NULL;
    char ch;
    int i,j=0;
    printf("歡迎使用本系統,按回車鍵進入系統\n");
    getchar();
    system("cls");
    do
    {
        output_view();
        printf("請選擇相應的操作\n");
        scanf("%c",&ch);
        switch(ch)
        {
        case '0':output_use();break;
        case '1':head=creat();break;
        case '2':save(head);break;
        case '3':output(head);break;
        case '4':head=openfile();break;
        case '5':system("cls");
            printf("1-按照編號排序\n");
            printf("2-按照姓名排序\n");
            scanf("%d",&i);
            switch(i)
            {
            case 1:sort_hao(head);break;
            case 2:sort_name(head);break;
            }
            break;
        case '6':search(head);break;
        case '7':head=add(head);break;
        case '8':head=delete_mem(head);break;
        case '9':head=change(head);break;
        case 'a':mima();break;
        case 'b':delete_doc();break;
        }
        printf("按回車鍵返回\n");
        getchar();
        system("cls");
        j=1;
    }while(j);
}

2.希望與大家共同努力,共同上進。

長風破浪會有時,直掛雲帆濟滄海!


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

-Advertisement-
Play Games
更多相關文章
  • ...
  • 在工作中遇到的Des解密問題,第三方發來的數據需要我們進行des解密,但是解密的結果前幾位始終是亂碼。廢了半天勁,終於找到了問題所在。 下麵先介紹一下des,瞭解des的同學可以直接看下麵的解決辦法。 Des加密 DES全稱為Data EncryptionStandard,即數據加密標準。Des加密 ...
  • 有時候我們有這樣一個需求:將動態生成的內容進行編譯 比如說用戶在客戶端瀏覽器輸入一段代碼傳到伺服器,伺服器拿到這段代碼進行編譯。 動態編譯的兩種做法: (1)通過Runtime調用javac,啟動新的進程去操作它。 Runtime runtime = Runtime.getRuntime(); Pr ...
  • 最近發現公司的測試環境中有個Socket服務的埠總是莫名其妙Down掉,但是服務卻正常運行著,看樣子是僵死了。。。 雖然是測試環境,但是也不能這樣放著不管,於是連夜寫了一個簡單的監控腳本。因為伺服器是Windows的,所以要用到wmi模塊。邏輯如下: 1、用wmi模塊獲取系統中處於停止狀態的服務, ...
  • 閑來無事用Python寫了一個簡陋的埠掃描腳本,其簡單的邏輯如下: 1. python DetectHostPort.py iplist.txt(存放著需要掃描的IP地址列表的文本,每行一個地址) 2. 輸入掃描埠、掃描時間和掃描間隔。 3. 輸出掃描信息。 下麵貼上源碼,歡迎拍磚。 運行時只能 ...
  • 列印結果 #java.util.Map<java.lang.String, com.coscon.reflectionTest.User>泛型參數類型:class java.lang.String泛型參數類型:class com.coscon.reflectionTest.User#java.uti ...
  • 今天訪問自己的網站的時候(by thinkphp),突然發現身份驗證失效了,Session無法跨頁,而且登陸的時候總是提示驗證碼錯誤(驗證碼也是通過Session傳遞的),才意識到可能是Session失效了。由於我租用的空間是IIS環境的,可能Session會存放在固定的位置,而那個位置對我來說是透 ...
  • 怎麼打包?代碼如下 package org.marsdroid; class Test{ public static void main(String args[]){ System.out.println("Hello package"); }} 關於打包,需要註意這幾點: 1、打包後的類,編譯方 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...