C語(yǔ)言使用單鏈表實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)
本文實(shí)例為大家分享了C語(yǔ)言使用單鏈表實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),供大家參考,具體內(nèi)容如下
初學(xué)數(shù)據(jù)結(jié)構(gòu),記錄一下學(xué)習(xí)過(guò)程。
運(yùn)行結(jié)果如圖:
1.運(yùn)行界面

2.錄入學(xué)生信息

3.按照總分進(jìn)行排序

代碼如下:
#define ERROR 0
#define OK 1
#define OVERFLOW -1;
typedef int ElemType;
typedef int Status;
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include<string.h>
#include<iostream>
typedef struct{
char name[20];
char snumber[20];
char sex[10];
int math;
int chinese;
int english;
}student;
typedef struct LNode{
student data;
struct LNode *next;
}LNode,*LinkList;
//單鏈表初始化
Status InitList(LinkList &L){
L = new LNode;
L->next = NULL;
return OK;
}
//創(chuàng)建單鏈表
void CreateList(LinkList &L,int n){
LinkList r;
LinkList p;
L = new LNode;
L->next = NULL;
r = L;
int i;
for(i = 0;i<n;i++){
p = new LNode;
scanf("%s%s%s%d%d%d",&p->data.name,&p->data.snumber,&p->data.sex,&p->data.chinese,&p->data.math,&p->data.english);
//scanf("%d%d%d",&p->data.chinese,&p->data.math,&p->data.english);
p->next=NULL;
r->next=p;
r = p;
}
}
//總分統(tǒng)計(jì)
int GradeSum(LinkList L){
int sum;
sum = (L->data.chinese)+(L->data.english)+(L->data.math);
return sum;
}
//統(tǒng)計(jì)所有學(xué)生信息
void BianLi(LinkList L){
LinkList p;
p = L->next;
printf("姓名\t學(xué)號(hào)\t性別\t語(yǔ)文\t數(shù)學(xué)\t英語(yǔ)\t總分\n");
while(p){
printf("%s\t%s\t%s\t",p->data.name,p->data.snumber,p->data.sex);
printf("%d\t%d\t%d\t%d",p->data.chinese,p->data.math,p->data.english,GradeSum(p));
p = p->next;
printf("\n");
}
}
//按照總分排序
void OrderSum(LinkList &L){
LinkList p,q,tail;
tail = NULL;
while((L->next->next) != tail)
{
p = L;
q = L->next;
while(q->next != tail)
{
if( GradeSum(q) < GradeSum(q->next))
{
p->next = q->next;
q->next = q->next->next;
p->next->next = q;
q = p->next;
}
q = q->next;
p = p->next;
}
tail = q;
}
printf("排序完畢!\n");
}
//根據(jù)語(yǔ)文進(jìn)行排序
void OrderChinese(LinkList &L){
LinkList p,q,tail;
tail = NULL;
while((L->next->next) != tail)
{
p = L;
q = L->next;
while(q->next != tail)
{
if((q->data.chinese) < (q->next->data.chinese))
{
p->next = q->next;
q->next = q->next->next;
p->next->next = q;
q = p->next;
}
q = q->next;
p = p->next;
}
tail = q;
}
printf("排序完畢!\n");
}
//根據(jù)英語(yǔ)進(jìn)行排序
void OrderEnglish(LinkList &L){
LinkList p,q,tail;
tail = NULL;
while((L->next->next) != tail)
{
p = L;
q = L->next;
while(q->next != tail)
{
if((q->data.english) < (q->next->data.english))
{
p->next = q->next;
q->next = q->next->next;
p->next->next = q;
q = p->next;
}
q = q->next;
p = p->next;
}
tail = q;
}
printf("排序完畢!\n");
}
//根據(jù)數(shù)學(xué)進(jìn)行排序
void OrderMath(LinkList &L){
LinkList p,q,tail;
tail = NULL;
while((L->next->next) != tail)
{
p = L;
q = L->next;
while(q->next != tail)
{
if((q->data.math) < (q->next->data.math))
{
p->next = q->next;
q->next = q->next->next;
p->next->next = q;
q = p->next;
}
q = q->next;
p = p->next;
}
tail = q;
}
printf("排序完畢!\n");
}
//刪除學(xué)生信息
Status ListDelete(LinkList &L,int i){
LinkList p;
LinkList q;
int j;
p = L;j = 0;
while((p->next)&&(j<i-1)){
p = p->next;
++j;
}
if(!(p->next)||(j>i-1)) return ERROR;
q = p->next;
p->next = q->next;
delete q;
return OK;
}
void DeleteStudent(LinkList &L){
int i;
printf("請(qǐng)輸入需要?jiǎng)h除的學(xué)生序號(hào)\n");
scanf("%d",&i);
ListDelete(L,i);
printf("刪除完畢!\n");
}
//插入學(xué)生信息
Status ListInsert(LinkList &L,int i,char name[],char snumber[],char sex[],int chinese,int math,int english){
LinkList p = L;
LinkList s;
int j = 0;
while(p && (j<i-1)){
p = p->next;
++j;
}
if(!p||j>i-1) return ERROR;
s = new LNode;
strcpy(s->data.name,name);
strcpy(s->data.snumber,snumber);
strcpy(s->data.sex,sex);
s->data.chinese = chinese;
s->data.math = math;
s->data.english = english;
s->next = p->next;
p->next = s;
return OK;
}
void InsertStudent(LinkList &L){
int n;
char name[20],snumber[20],sex[10];
int chinese,math,english;
printf("請(qǐng)輸入插入的位置N:");
scanf("%d",&n);
printf("請(qǐng)依次輸入學(xué)生的姓名、學(xué)號(hào)、性別、語(yǔ)文成績(jī)、數(shù)學(xué)成績(jī)、英語(yǔ)成績(jī)、總分\n");
scanf("%s%s%s%d%d%d",&name,&snumber,&sex,&chinese,&math,&english);
ListInsert(L,n,name,snumber,sex,chinese,math,english);
}
void menu(){
printf("\t\t\t ======================================================\n\n");
printf("\t\t\t ‖ 學(xué)生信息管理系統(tǒng) ‖ \n\n");
printf("\t\t\t ======================================================\n\n");
printf("\t\t\t ===================系統(tǒng)功能菜單=======================\n");
printf("\t\t\t ‖ ------------------------------------------------ ‖\n");
printf("\t\t\t ‖ ------------------------------------------------ ‖ \n");
printf("\t\t\t ====================================================== \n");
printf("\t\t\t ‖ 0.錄入學(xué)生信息 ‖ ‖ 1.統(tǒng)計(jì)學(xué)生信息 ‖ \n");
printf("\t\t\t ======================================================\n");
printf("\t\t\t ‖ 2.按照總分排序 ‖ ‖ 3.按照語(yǔ)文成績(jī)排序 ‖ \n");
printf("\t\t\t ====================================================== \n");
printf("\t\t\t ‖ 4.按照數(shù)學(xué)成績(jī)排序 ‖ ‖ 5.按英語(yǔ)成績(jī)排序 ‖ \n");
printf("\t\t\t ======================================================\n");
printf("\t\t\t ‖ 6.刪除學(xué)生信息 ‖ ‖ 7.插入學(xué)生信息 ‖ \n");
printf("\t\t\t ====================================================== \n");
printf("\t\t\t ‖ 8.退出系統(tǒng) ‖ \n");
printf("\t\t\t ========================== \n");
printf("\t\t\t ----------------------------------------------- \n");
printf("\n\n\n");
}
void luRu(LinkList &L){
int n;
printf("請(qǐng)輸入學(xué)生數(shù)目N:");
scanf("%d",&n);
printf("請(qǐng)依次輸入學(xué)生的姓名、學(xué)號(hào)、性別、語(yǔ)文成績(jī)、數(shù)學(xué)成績(jī)、英語(yǔ)成績(jī)、總分\n");
CreateList(L,n);
printf("學(xué)生信息已錄入完畢!\n");
}
void main(int args,char argv[]){
LinkList p;
InitList(p);
int i;
do{
menu();
scanf("%d",&i);
getchar();
switch(i){
case 0:luRu(p);break;
case 1:BianLi(p);break;
case 2:OrderSum(p);BianLi(p);break;
case 3:OrderChinese(p);BianLi(p);break;
case 4:OrderMath(p);BianLi(p);break;
case 5:OrderEnglish(p);BianLi(p);break;
case 6: DeleteStudent(p);break;
case 7:InsertStudent(p);break;
case 8:exit(0);
}
}while(i != -1);
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Linux UDP服務(wù)端和客戶端程序的實(shí)現(xiàn)
這篇文章主要介紹了Linux UDP服務(wù)端和客戶端程序的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
C語(yǔ)言實(shí)現(xiàn)字符串字符反向排列的方法詳解
這篇文章主要為大家分享了幾種通過(guò)C語(yǔ)言實(shí)現(xiàn)字符串字符反向排列(不是逆序打?。┑姆椒?,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-05-05
C++中map和vector作形參時(shí)如何給定默認(rèn)參數(shù)?
今天小編就為大家分享一篇關(guān)于C++中map和vector作形參時(shí)如何給定默認(rèn)參數(shù)?,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-04-04
C++?qt實(shí)現(xiàn)打開(kāi)關(guān)閉狀態(tài)按鈕的代碼
這篇文章主要介紹了C++?qt實(shí)現(xiàn)打開(kāi)關(guān)閉狀態(tài)按鈕,用QCheckBox可以實(shí)現(xiàn),只要在選擇與未選擇的狀態(tài)設(shè)置不同的圖片即可完成,代碼簡(jiǎn)單易懂,需要的朋友可以參考下2022-03-03

