用c語言寫一個課程管理系統,c語言圖書管理系統課程設計

本文目錄一覽:

C語言程序設計之學生選修課程管理系統。

#include stdio.h

#include stdlib.h

#include string.hstruct student

{

char name[60];

char ID[7];

int score;

};int dq(struct student st[]);

void xianshi();

void bc(struct student st[]);

void add();

void select();

void zz();

void chazhao();

void xhcz();

void xmcz();

void del();

void xmsc();

void xhsc();

void tj();

void px();

void bjg();

void xg();

void xhxg();

void xmxg();

void bca();

void fh();

struct student st[300]; //這個數組用來保存所有的學生信息 和文件裡面的一致

int Number=0; //記錄總的學生人數 也就是數組/文件裡面的學生人數

void main()

{

int choose=0;

FILE *fp=NULL;

char yesorno;

if((fp=fopen(“C://student.dat”,”rb”))==NULL)

{

printf(“\n=========提示:文件不存在,是否要創建一個?(y/n)\n”);

scanf(“%c”,yesorno);

if(yesorno==’y’||yesorno==’Y’)

{

//這裡僅為了建立文件

fp=fopen(“C://student.dat”,”wb”);

fclose(fp);

}

else

exit(0);

}

else

{

Number=dq(st); //要是文件只能夠已經有數據 將數據初始化到數組中

}

system(“cls”);

while(true)

{

xianshi();

printf(“\t\t====請選擇:”);

scanf(“%d”,choose);

system(“cls”);

switch(choose)

{

case 0: exit(0);

//退出

break;

case 1: add();

fh();//增加學生成績

break;

case 2: select();

fh();//查看學生成績

break;

case 3: chazhao();

fh();// 查找

break;

case 4: del();

fh();//刪除

break;

case 5: tj();

fh();//統計

break;

case 6: px();

fh();//排序

break;

case 7: bjg();

fh();//輸出不及格

break;

case 8: xg();

fh();//修改

break;

case 9:zz();

fh();//作者

break;

case 10:bca();

fh();//保存

break;

default:

break;

}

fflush(stdin);

getchar();

system(“cls”);

}

}

void bca()

{

printf(“\t=====程序在運行時已自動保存…..\n”);

}

void fh()

{

printf(“\t===按Enter鍵返回主菜單\n”);

}

void xg() //修改學生信息

{

int way=0;

printf(“請選擇修改查找方式\n”);

printf(“1 按姓名查找修改\n”);

printf(“2 按學號查找修改\n”);

scanf(“%d”,way);

switch(way)

{

case 1: xmxg();

break;

case 2: xhxg();

break;

default: printf(“輸入有誤,結束!\n”);

break;

}

}

//按姓名修改

void xmxg()

{

FILE *fp=NULL;

char name[60];

int i=0;

int changeIndex=0;

int index=0;

printf(“請輸入要修改的學生姓名:”);

scanf(“%s”,name);

for (i=0;iNumber;i++)

{

if (strcmp(name,st[i].name))

{

changeIndex=i; //保存要修改的人的下標

}

break;

}

printf(“\t姓名\t學號\t成績\n”);

printf(“\t%s\t%s\t%d\n\n”,st[changeIndex].name,st[changeIndex].ID,st[changeIndex].score);

printf(“請重新輸入該學生信息”);

printf(“姓名:”);

scanf(“%s”,st[changeIndex].name);

printf(“學號:”);

scanf(“%s”,st[changeIndex].ID);

printf(“成績:”);

scanf(“%d”,st[changeIndex].score); //信息修改後重新更新文件裡面的數據 以保持數據一致性

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

}

void xhxg()//按學號修改

{

FILE *fp=NULL;

char id[60];

int i=0;

int changeIndex=0;

int index=0;

printf(“請輸入要修改的學生學號:”);

scanf(“%s”,id);

for (i=0;iNumber;i++)

{

if (strcmp(id,st[i].ID))

{

changeIndex=i; //保存要修改的人的下標

}

break;

}

printf(“\t姓名\t學號\t成績\n”);

printf(“\t%s\t%s\t%d\n\n”,st[changeIndex].name,st[changeIndex].ID,st[changeIndex].score);

printf(“請重新輸入該學生信息”);

printf(“姓名:”);

scanf(“%s”,st[changeIndex].name);

printf(“學號:”);

scanf(“%s”,st[changeIndex].ID);

printf(“成績:”);

scanf(“%d”,st[changeIndex].score);

//信息修改後重新更新文件裡面的數據 以保持數據一致性

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

printf(“\t=======修改成功\n”);

}void bjg() //輸出不及格人數

{

int i=0;

printf(“以下是不及格:\n”);

printf(“\t姓名\t學號\t成績\n”);

for (i=0;iNumber;i++)

{

if (st[i].score60)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

}

void px()//排序

{

struct student temp;

int wantNUmber=0;

int i=0;

int j=0;

for(i=0;iNumber-1;i++)

{

for(j=i;jNumber-1;j++)

{

if(st[j].scorest[j+1].score)

{

temp=st[j];

st[j]=st[j+1];

st[j+1]=temp;

}

}

}

printf(“你想輸出前幾名的成績:”);

scanf(“%d”,wantNUmber);

if (wantNUmberNumber)

{

wantNUmber=Number;

} printf(“\t姓名\t學號\t成績\n”);

for(i=0;iwantNUmber;i++)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

void tj()//統計

{

int i=0;

double sum=0.0;

for(i=0;iNumber;i++)

{

sum+=st[i].score;

}

printf(“全班總分為:%f\n”,sum);

printf(“平均分為:%f\n”,sum/Number);

}

void del()//刪除

{

int n=0;

printf(“1 按姓名刪除\n”);

printf(“2 按學號刪除\n”);

scanf(“%d”,n);

switch(n)

{

case 1: xmsc();

break;

case 2: xhsc();

break;

}

}

void xmsc()//按姓名刪除

{

FILE *fp=NULL;

char name[60];

int i=0;

int j=0;

printf(“請輸入要刪除的學生姓名:”);

scanf(“%s”,name);

for(i=0;iNumber;i++)

{

if (strcmp(name,st[i].name)==0) //如果查找到就刪除

{

for (j=i;jNumber-1;j++)

{

st[j]=st[j+1];

}

Number–;

}

} //將剩餘數據寫入文件 重新一寫的方式打開文件 把以前的數據擦除了

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

printf(“刪除成功;\n”);

}

void xhsc()//按學號刪除

{

FILE *fp=NULL;

char id[60];

int i=0;

int j=0;

printf(“請輸入要刪除的學生學號:”);

scanf(“%s”,id);

for(i=0;iNumber;i++)

{

if (strcmp(id,st[i].ID)==0) //如果查找到就刪除

{

for (j=i;jNumber-1;j++)

{

st[j]=st[j+1];

}

Number–;

}

}

//將剩餘數據寫入文件 重新一寫的方式打開文件 把以前的數據擦除了

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

printf(“刪除成功;\n”);

}

void chazhao()//查找學生

{

int n=0;

printf(“1 按姓名查找\n”);

printf(“2 按學號查找\n”);

scanf(“%d”,n);

switch(n)

{

case 1: xmcz();

break;

case 2: xhcz();

break;

default: printf(“輸入有誤,結束!\n”);

break;

}

}

void xhcz()//按學號查找

{

char id[7];

int i=0;

printf(“請輸入要查找學生學號:”);

scanf(“%s”,id);

system(“cls”);

printf(“\t姓名\t學號\t成績\n”);

for (i=0;iNumber;i++)

{

if (strcmp(id,st[i].ID)==0)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

}

void xmcz()//按姓名查找

{

char name[7];

int i=0;

printf(“請輸入要查找學生姓名:”);

scanf(“%s”,name);

system(“cls”);

printf(“\t姓名\t學號\t成績\n”);

for (i=0;iNumber;i++)

{

if (strcmp(name,st[i].name)==0)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

}

void zz()

{

printf(“\t**********************************************************\n\n”);

printf(“\t^^^^^^^^^^ 武漢工程大學郵電與信息工程學院 ^^^^^^^^^^\n\n”);

printf(“\t^^^^^^^^^ 07網絡與安全管理2班 ^^^^^^^^^\n\n”);

printf(“\t^^^^^^^^ 易樊製作 ^^^^^^^^\n\n”);

printf(“\t^^^^^^^^^ 禁止CTRL+C 謝謝合作 ^^^^^^^^^\n\n”);

printf(“\t^^^^^^^^^^ QQ:895115828\n\n”);

printf(“\t**********************************************************\n\n”);

}

void select()//查看學生

{

int i=0;

printf(“以下是全部學生成績\n”);

printf(“\t姓名\t學號\t成績\n”);

for(i=0;iNumber;i++)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

void add()//增加學生

{

int numberTemp=0;

int i=0;

struct student temp; //臨時保存信息

printf(“請輸入要增加學生成績個數:”);

scanf(“%d”,numberTemp);

for(i=0;inumberTemp;i++)

{

printf(“輸入第%d個同學信息\n”,i+1);

printf(“姓名:”);

scanf(“%s”,temp.name);

printf(“學號:”);

scanf(“%s”,temp.ID);

printf(“成績:”);

scanf(“%d”,temp.score);

st[Number++]=temp; //將剛添加的寫入到數組

bc(temp); //將剛添加的寫入到文件 }

printf(“添加成功\n”);

}

void bc(struct student *st)

{

FILE *fp=NULL;

fp=fopen(“C://student.dat”,”ab+”);

fwrite(st,sizeof(struct student),1,fp);

fclose(fp);

}

int dq(struct student st[])

{

FILE *fp=NULL;

int i=0;

fp=fopen(“C://student.dat”,”rb”);

while(fread(st[i],sizeof(struct student),1,fp))

i++;

fclose(fp);

return i;

}

void xianshi()

{

printf(“\t*****************************************************************\n”);

printf(“\t* *\n”);

printf(“\t* 學生成績管理系統 *\n”);

printf(“\t* *\n”);

printf(“\t* [1] 增加學生成績 [2] 查看學生成績 *\n”);

printf(“\t* [3] 查找學生成績 [4] 刪除學生成績 *\n”);

printf(“\t* [5] 統計(總成績和平均分) [6] 輸出前N名學生成績 *\n”);

printf(“\t* [7] 輸出不及格人數 [8] 修改學生信息 *\n”);

printf(“\t* [9] 關於作者 [10] 保存數據 *\n”);

printf(“\t* [0] 退出系統 *\n”);

printf(“\t*****************************************************************\n”);

}運行成功,請你下去後慢慢研究下這個程序,很簡單的,祝你成功!~

用C語言設計一個課程信息管理系統

#include iostream

#include string

#include iomanip

#include fstream

using namespace std;

struct List

{

string m_Name;

string m_ID;//可能有的學號里有字母,所以用string類型。

short int m_Chinese;

short int m_Match;

short int m_English;

struct List *Next; //指針域。

};

typedef struct List Node;

typedef Node *Link;

//—————函數聲明——————-

Link Create(Link Head);

Link Search(Link Head);

Link Search_front(Link Head);

void Release(Link Head);

void Display(Link Head);

void Display_One(Link Head);

void Display(Link Head,fstream ofile);

Link AddInfo(Link Head);

Link DelInfo(Link Head);

Link Modify(Link Head);

void Grade_Stat(Link Head);

Link Sort(Link Head);

//—————函數實現——————-

Link Create(Link Head)

{

/*構造一個頭節點*/

Head=(Link)new Node;

if(!Head)

{

cout”分配內存失敗。”endl;

exit(-1);

}

Head-m_Name=””;

Head-m_ID=””;

Head-m_Chinese=0;

Head-m_Match=0;

Head-m_English=0;

Head-Next=NULL;

return Head;

}

Link Search(Link Head)

{

cout” 1.按姓名查詢 2.按學號查詢 “endl;

int select;

cinselect;

while(cin.fail())

{

cout”請選擇正確的菜單項:”;

cin.clear();

fflush(stdin);

cinselect;

}

Link ptr;

ptr=Head;

if(select==1)

{

string name;

cout”請輸入要查詢的姓名:”;

cinname;

while(ptr!=NULL)

{

if(ptr-m_Name==name)

{

Display_One(ptr);

return ptr;

}

ptr=ptr-Next;

}

cout”沒找到,怎麼辦?”endl;

}

else if(select==2)

{

string ID;

cout”請輸入要查詢的學號:”;

cinID;

while(ptr!=NULL)

{

if(ptr-m_ID==ID)

{

Display_One(ptr);

return ptr;

}

ptr=ptr-Next;

}

cout”沒找到,怎麼辦?”endl;

}

return ptr;

}

Link Search_front(Link Head)

{//返回前驅節點。

cout” 1.按姓名刪除 2.按學號刪除 “endl;

int select;

cinselect;

while(cin.fail())

{

cout”請選擇正確的菜單項:”;

cin.clear();

fflush(stdin);

cinselect;

}

Link ptr;

Link front;

ptr=Head-Next;

front=Head;

if(select==1)

{

string name;

cout”請輸入要刪除的姓名:”;

cinname;

while(ptr!=NULL)

{

if(ptr-m_Name==name)

{

Display_One(ptr);

return front;

}

ptr=ptr-Next;

front=front-Next;

}

cout”沒找到,怎麼辦?”endl;

}

else if(select==2)

{

string ID;

cout”請輸入要刪除的學號:”;

cinID;

while(ptr!=NULL)

{

if(ptr-m_ID==ID)

{

Display_One(ptr);

return front;

}

ptr=ptr-Next;

front=front-Next;

}

cout”沒找到,怎麼辦?”endl;

}

return front;

}

void Release(Link Head)

{

Link ptr;

while(Head!=NULL)

{

ptr=Head;

Head=Head-Next;

delete ptr;

}

}

void Display(Link Head)

{

Link ptr;

ptr=Head-Next;

cout”———————————————————————-“endl;

cout”—————————- 所有學生信息 ————————–“endl;

cout”—姓名——–學號———–語文———–數學———–英語——“endl;

while(ptr!=NULL)

{

coutsetw(15)leftptr-m_Name

setw(15)leftptr-m_ID

setw(15)leftptr-m_Chinese

setw(15)leftptr-m_Match

setw(15)leftptr-m_Englishendl;

ptr=ptr-Next;

}

}

void Display(Link Head,fstream ofile)

{

Link ptr;

ptr=Head-Next;

ofile”———————————————————————-“endl;

ofile”—————————- 所有學生信息 ————————–“endl;

ofile”—姓名——–學號———–語文———–數學———–英語——“endl;

while(ptr!=NULL)

{

ofilesetw(15)leftptr-m_Name

setw(15)leftptr-m_ID

setw(15)leftptr-m_Chinese

setw(15)leftptr-m_Match

setw(15)leftptr-m_Englishendl;

ptr=ptr-Next;

}

}

void Display_One(Link Head)

{

Link ptr;

ptr=Head;

cout”———————————————————————-“endl;

cout”—————————- 查詢結果信息 ————————–“endl;

cout”—姓名——–學號———–語文———–數學———–英語——“endl;

coutsetw(15)leftptr-m_Name

setw(15)leftptr-m_ID

setw(15)leftptr-m_Chinese

setw(15)leftptr-m_Match

setw(15)leftptr-m_Englishendl;

}

Link AddInfo(Link Head)

{

Link ptr;

ptr=Head;

while(ptr-Next!=NULL)

{

ptr=ptr-Next;

}

Link ptr2;

char again;

do

{

ptr2=(Link)new Node;

if(!ptr2)

{

cout”內存分配失敗!”endl;

exit(-1);

}

//數據域

string Name,ID;

short int Chinese,Match,English;

cout”輸入姓名:”;

cinName;

coutendl”輸入學號:”;

cinID;

coutendl”語文成績:”;

cinChinese;

coutendl”數據成績:”;

cinMatch;

coutendl”英語成績:”;

cinEnglish;

ptr2-m_Name=Name;

ptr2-m_ID=ID;

ptr2-m_Chinese=Chinese;

ptr2-m_Match=Match;

ptr2-m_English=English;

//指針域

ptr2-Next=NULL;//作為尾節點。

ptr-Next=ptr2;//連接入鏈表。

ptr=ptr2;//將ptr2作為下一次產生的節點的前驅節點.

cout”是否繼續輸入?(Y/N) “;

cinagain;

}while(again==’Y’||again==’y’);

return Head;

}

Link DelInfo(Link Head)

{

Link ptr;

Link ptr2;

ptr=Head;

Link f_ptr;//前驅節點。

f_ptr=Search_front(ptr);

ptr2=f_ptr-Next;

f_ptr-Next=f_ptr-Next-Next;

delete ptr2;

return Head;

}

Link Modify(Link Head)

{

Link ptr;

ptr=Head;

ptr=Search(ptr);

cout”修改前信息為:”endl;

Display_One(ptr);

//cout”請選擇你要修改的選項:A:姓名 B:學號 C:語文成績 D:數學成績 E:英語成績”endl;

string name,ID;

float Chinese,Match,English;

cout”輸入新姓名:”;

cinname;

coutendl”輸入新學號:”;

cinID;

coutendl”輸入新語文成績:”;

cinChinese;

coutendl”輸入新數學成績:”;

cinMatch;

coutendl”輸入新英語成績:”;

cinEnglish;

ptr-m_Name=name;

ptr-m_ID=ID;

ptr-m_Chinese=Chinese;

ptr-m_Match=Match;

ptr-m_English=English;

coutendl”修改後信息為:”endl;

Display_One(ptr);

return Head;

}

void Grade_Stat(Link Head)

{//成績統計。

Link ptr;

ptr=Head;

cout”請輸入你要查詢的課程名(chinese|match|english)和一個分數範圍[min,max].”endl;

string name;

short int min,max;

int SwitchNum;

cout”課程名:”;

cinname;

coutendl”分數下限:”;

cinmin;

coutendl”分數上限:”;

cinmax;

if(name==”chinese”)

SwitchNum=1;

else if(name==”match”)

SwitchNum=2;

else if(name==”english”)

SwitchNum=3;

else

{

cout”請輸入一個正確的課程名:”endl;

return;

}

while(ptr!=NULL)

{

switch(SwitchNum)

{

case 1:

if(ptr-m_Chinese=maxptr-m_Chinese=min)

Display_One(ptr);

break;

case 2:

if(ptr-m_Match=maxptr-m_Match=min)

Display_One(ptr);

break;

case 3:

if(ptr-m_English=maxptr-m_English=min)

Display_One(ptr);

}

}

}

Link Sort(Link Head)

{//我創建的是帶頭節點的鏈表。用直接插入法。

cout”請輸入你想排序的課程名(用中文):”;

string course_name;

cincourse_name;

if((Head-Next==NULL)||(Head-Next-Next==NULL))//此步條件判斷非常有價值。

{

cout”數據節點數少於2個,不用排序!”endl;

return Head;

}

//———–第二步;

Link ptr;

Link ptr_F;

Link ptr_N;

ptr=Head-Next-Next;

ptr_F=Head;

Head-Next-Next=NULL;//到此,分成了兩個鏈表。

//第三步。

while(ptr)

{

ptr_N=ptr-Next;

ptr_F=Head;//ptr_F的歸位。

while(ptr_F-Next)

{

if(course_name==”語文”)

{

if(ptr-m_Chineseptr_F-Next-m_Chinese)

{

ptr-Next=ptr_F-Next;

ptr_F-Next=ptr;

break;

}//if

else

{

ptr_F=ptr_F-Next;

}

}

if(course_name==”數學”)

{

if(ptr-m_Matchptr_F-Next-m_Match)

{

ptr-Next=ptr_F-Next;

ptr_F-Next=ptr;

break;

}//if

else

{

ptr_F=ptr_F-Next;

}

}

if(course_name==”英語”)

{

if(ptr-m_Englishptr_F-Next-m_English)

{

ptr-Next=ptr_F-Next;

ptr_F-Next=ptr;

break;

}//if

else

{

ptr_F=ptr_F-Next;

}

}

}//while(ptr_F-Next)

if(ptr_F-Next==NULL)

{

ptr-Next=ptr_F-Next;

ptr_F-Next=ptr;//表示插到有序鏈表的最後面了。

}

ptr=ptr_N;//歸位,準備下一次排序。

}//while(ptr)

cout”從高到低,排序成功!”endl;

return Head;

}

//———-主函數———————-

int main()

{

fstream ofile;

ofile.open(“e:\\student.txt”,ios_base::out);

if(!ofile)

{

cout”文件打開失敗。”endl;

exit(-1);

}

Link head=0;

head=Create(head);

while(1)

{

cout”*****************************************************”endl;

cout”*** 1.添加信息 2.修改信息 3.刪除信息 4.信息查詢 ***”endl;

cout”*** 5.成績統計 6.排 序 7.顯示/保存 0.退 出 ***”endl;

cout”*****************************************************”endl;

cout”請選擇正確的菜單項:”;

int sel;

cinsel;

while(cin.fail())

{

cout”請選擇正確的菜單項:”;

cin.clear();

fflush(stdin);

cinsel;

}

switch(sel)

{

case 0:

exit(0);

case 1:

head=AddInfo(head);

break;

case 2:

head=Modify(head);

break;

case 3:

head=DelInfo(head);

break;

case 4:

Search(head);

break;

case 5:

Grade_Stat(head);

break;

case 6:

Sort(head);

break;

case 7:

Display(head);//在標準顯示器上顯示。

Display(head,ofile);//在文件中顯示。

break;

default:

break;

}

}

Release(head);

return 0;

}

換一下漢字就好了

用C語言寫一個 學生選課系統

#includestdio.h

#includestdlib.h

int N1,N2,kk1,kk2,kk3;

struct couse * head1;

struct student * head2;

struct couse//課程信息結構體

{

int num1;

char name1[20];

int score;

int nelepeo;//課程已選人數

int Melepeo;//課程人數上限

struct couse * next;

};

struct student//學生信息結構體

{

int num2;

char name2[20];

int nelenum[50];//已選課程編號

int nelen;//已選課程數量

struct student * next;

};

void Ms()

{

for(kk1=0;kk11100;kk1++)

for(kk2=0;kk21200;kk2++)

for(kk3=0;kk31200;kk3++);

}

void keyboardc()//錄入課程子函數(從鍵盤錄入)

{

struct couse *p1,*p2;

N1=0;

p1=p2=(struct couse*)malloc(sizeof(struct couse));

printf(“課程編號\t課程名稱\t學分\t課程人數上限\n”);

scanf(“%d%s%d%d”,p1-num1,p1-name1,p1-score,p1-Melepeo);

p1-nelepeo=0;

head1=NULL;

while(p1-num1!=0)

{

N1=N1+1;

if(N1==1)head1=p1;

else p2-next=p1;

p2=p1;

p1=(struct couse * )malloc(sizeof(struct couse));

scanf(“%d%s%d%d”,p1-num1,p1-name1,p1-score,p1-Melepeo);

p1-nelepeo=0;

}

p2-next=NULL;

}

void filec()//錄入鍵盤子函數(從文件錄入)

{

FILE * fp;

char filepath[20];

struct couse *p1,*p2;

N1=0;

printf(“輸入要讀入的文件路徑:”);

getchar();

gets(filepath);

if((fp=fopen(filepath,”r”))==NULL)

{

printf(“找不到%s文件!\n”,filepath);

exit(0);

}

p1=p2=(struct couse*)malloc(sizeof(struct couse));

fscanf(fp,”%d%s%d%d%d”,p1-num1,p1-name1,p1-score,p1-nelepeo,p1-Melepeo);

head1=NULL;

while(!feof(fp))

{

N1=N1+1;

if(N1==1)head1=p1;

else p2-next=p1;

p2=p1;

p1=(struct couse * )malloc(sizeof(struct couse));

fscanf(fp,”%d%s%d%d%d”,p1-num1,p1-name1,p1-score,p1-nelepeo,p1-Melepeo);

}

p2-next=NULL;

}

void inputc()//錄入課程主函數

{

int i;

printf(“\t\t\t錄入課程信息\n”);

printf(“\n1.從鍵盤錄入\n”);

printf(“2.從文件錄入\n”);

printf(“3.返回主菜單\n”);

printf(“請選擇(1~3):\n”);

scanf(“%d”,i);

switch(i)

{

case(1):keyboardc();break;

case(2):filec();break;

case(3):break;

}

}

void insertc(struct couse *incouse)//課程管理子函數(增加課程)

{

struct couse *p0,*p1,*p2;

p1=head1;

p0=incouse;

if(head1==NULL)

{

head1=p0;

p0-next=NULL;

}

else

{

while((p0-num1 p1-num1) (p1-next!=NULL))

{

p2=p1;

p1=p1-next;

}

if(p0-num1 = p1-num1)

{

if(head1==p1) head1=p0;

else p2-next=p0;

p0-next=p1;

}

else

{

p1-next=p0;

p0-next=NULL;

}

}

N1=N1+1;

}

void delc(int num1)//課程管理子函數(刪除課程)

{

struct couse *p1,*p2;

if(head1==NULL)

{

printf(“\n沒有課程,無法刪除!\n”);

goto end;

}

p1=head1;

while(num1!=p1-num1 p1-next!=NULL)

{

p2=p1;

p1=p1-next;

}

if(num1==p1-num1)

{

if(p1==head1) head1=p1-next;

else p2-next=p1-next;

printf(“已刪除該編號課程!\n”);

N1=N1-1;

}

else printf(“無該編號的課程!\n”);

end:;

}

void managementc()//課程管理主函數

{

struct couse * incouse;

int i,num1;

printf(“\t\t\t課程管理\n”);

printf(“1.新增課程\n”);

printf(“2.刪除課程\n”);

printf(“3.返回主菜單\n”);

printf(“請選擇(1~3):\n”);

scanf(“%d”,i);

switch(i)

{

case(1):

{

incouse=(struct couse *)malloc(sizeof(struct couse));

printf(“課程編號\t課程名稱\t學分\t課程人數上限\n”);

scanf(“%d%s%d%d”,incouse-num1,incouse-name1,incouse-score,incouse-Melepeo);

incouse-nelepeo=0;

insertc(incouse);

break;

}

case(2):

{

printf(“請輸入要刪除課程的編號:\n”);

scanf(“%d”,num1);

delc(num1);

break;

}

case(3):break;

}

}

void keyboards()//錄入學生信息子函數(從鍵盤錄入)

{

int i;

struct student *p1,*p2;

N2=0;

p1=p2=(struct student *)malloc(sizeof(struct student));

printf(“學生學號\t學生姓名\n”);

scanf(“%d%s”,p1-num2,p1-name2);

p1-nelen=0;

for(i=0;i20;i++) p1-nelenum[i]=0;

head2=NULL;

while(p1-num2!=0)

{

N2=N2+1;

if(N2==1)head2=p1;

else p2-next=p1;

p2=p1;

p1=(struct student * )malloc(sizeof(struct student));

scanf(“%d%s”,p1-num2,p1-name2);

p1-nelen=0;

for(i=0;i20;i++) p1-nelenum[i]=0;

}

p2-next=NULL;

}

void files()//錄入學生信息子函數(從文件錄入)

{

int i=0;

FILE * fp;

char filepath[20];

struct student *p1,*p2;

N2=0;

printf(“輸入要讀入的文件路徑:”);

getchar();

gets(filepath);

if((fp=fopen(filepath,”r”))==NULL)

{

printf(“找不到%s文件!\n”,filepath);

exit(0);

}

p1=p2=(struct student*)malloc(sizeof(struct student));

fread(p1,sizeof(struct student),1,fp);

head2=NULL;

while(!feof(fp))

{

i=0;

N2=N2+1;

if(N2==1)head2=p1;

else p2-next=p1;

p2=p1;

p1=(struct student * )malloc(sizeof(struct student));

fread(p1,sizeof(struct student),1,fp);

}

p2-next=NULL;

}

void inputs()//錄入學生信息主函數

{

int i;

printf(“\t\t\t錄入學生信息\n”);

printf(“\n1.從鍵盤錄入\n”);

printf(“2.從文件錄入\n”);

printf(“3.返回主菜單\n”);

printf(“請選擇(1~3):\n”);

scanf(“%d”,i);

switch(i)

{

case(1):keyboards();break;

case(2):files();break;

case(3):break;

}

}

void inserts(struct student * incouse)//學生信息管理子函數(填加學生信息)

{

struct student *p0,*p1,*p2;

p1=head2;

p0=incouse;

if(head2==NULL)

{

head2=p0;

p0-next=NULL;

}

else

{

while((p0-num2 p1-num2) (p1-next!=NULL))

{

p2=p1;

p1=p1-next;

}

if(p0-num2 = p1-num2)

{

if(head2==p1) head2=p0;

else p2-next=p0;

p0-next=p1;

}

else

{

p1-next=p0;

p0-next=NULL;

}

}

N2=N2+1;

}

void dels(int num2)//學生信息管理子函數(刪除學生信息)

{

struct student *p1,*p2;

if(head2==NULL)

{

printf(“\n沒有該學生信息,無法刪除!\n”);

goto end;

}

p1=head2;

while(num2!=p1-num2 p1-next!=NULL)

{

p2=p1;

p1=p1-next;

}

if(num2==p1-num2)

{

if(p1==head2) head2=p1-next;

else p2-next=p1-next;

printf(“已刪除該學生信息!\n”);

N2=N2-1;

}

else printf(“無該學號的學生!\n”);

end:;

}

void managements()//學生信息管理主函數

{

struct student * incouse;

int i,num2;

printf(“\t\t\t學生信息管理\n”);

printf(“1.新增學生信息\n”);

printf(“2.刪除學生信息\n”);

printf(“3.返回主菜單\n”);

printf(“請選擇(1~3):\n”);

scanf(“%d”,i);

switch(i)

{

case(1):

{

incouse=(struct student *)malloc(sizeof(struct student));

incouse-nelen=0;

incouse-nelenum[0]=0;

printf(“學生學號\t學生姓名\n”);

scanf(“%d%s”,incouse-num2,incouse-name2);

inserts(incouse);

break;

}

case(2):

{

printf(“請輸入要刪除學生的學號:\n”);

scanf(“%d”,num2);

dels(num2);

break;

}

case(3):break;

}

}

void elect(struct student * s)//選課

{

struct couse * p;

int num1,i;

printf(“請輸入要選課的編號:\n”);

scanf(“%d”,num1);

for(i=0;s-nelenum[i]!=0;i++);

s-nelenum[i]=num1;

(s-nelen)++;

p=head1;

while(p-num1!=num1) p=p-next;

(p-nelepeo)++;

}

void cheak()//學生選課子函數(查詢可選課程)

{

char e;

struct couse * c;

struct student * s;

int num2,i,j=0,t=0;

printf(“請輸入你的學號:”);

scanf(“%d”,num2);

s=head2;

while(s-num2!=num2 s-next!=NULL) s=s-next;

if(s-num2!=num2)

{

printf(“不存在你的信息,請進入主菜單錄入你的信息!\n”);

goto end;

}

c=head1;

printf(“你的可選課程編號:\n”);

while(c!=NULL)

{

for(t=0,i=0;s-nelenum[i]!=0;i++)

{

if(c-num1==s-nelenum[i]) t=1;

}

if(t==0 (c-nelepeo!=c-Melepeo))

{

printf(“%d\n”,c-num1);

j++;

}

c=c-next;

}

if(j==0)

{

printf(“你已選完所有課程,無法再多選!\n”);

goto end;

}

printf(“選課(y/n)?:\n”);

getchar();

e=getchar();

i=0;

while(e==’y’)

{

elect(s);

printf(“繼續選課(y/n)?:\n”);

getchar();

e=getchar();

}

end:;

}

void back(struct student * p)//退課

{

struct couse * p1;

int num1,i,j;

printf(“請輸入你要退掉的課程編號:\n”);

scanf(“%d”,num1);

p1=head1;

while(p1-num1!=num1) p1=p1-next;

for(i=0;p-nelenum[i]!=num1;i++);

for(j=i;p-nelenum[j]!=0;j++) p-nelenum[j]=p-nelenum[j+1];

p-nelenum[–j]=0;

(p1-nelepeo)–;

printf(“退課成功!\n”);

}

void hcheak()//學生選課子函數(查詢已選課程)

{

char c;

struct couse * p0;

struct student * p;

int num2,i,f=0;

printf(“請輸入學號:\n”);

scanf(“%d”,num2);

p=head2;

while(p-num2!=num2 p!=NULL) p=p-next;

if(p==NULL)

{

printf(“不存在你的信息,請回主菜單錄入信息:\n”);

goto end;

}

printf(“已選課程編號:\n”);

if(p-nelenum[0]==0)

{

printf(“你還沒選課!\n”);

goto end;

}

for(i=0;p-nelenum[i]!=0;i++)

{

printf(“%d\n”,p-nelenum[i]);

p0=head1;

while(p0-num1!=p-nelenum[i]) p0=p0-next;

f=f+p0-score;

}

printf(“總學分:%d\n”,f);

printf(“是否進行退課(y/n)?”);

getchar();

c=getchar();

while(c==’y’)

{

back(p);

printf(“繼續退課(y/n)?”);

getchar();

c=getchar();

(p-nelen)–;

}

end:;

}

void elective()//學生選課主函數

{

int i;

printf(“\t\t\t學生選課\n”);

printf(“1.查詢可選課程\n”);

printf(“2.查詢已選課程\n”);

printf(“3.返回主菜單\n”);

printf(“請輸入(1~3):\n”);

scanf(“%d”,i);

switch(i)

{

case(1):cheak();break;

case(2):hcheak();break;

case(3):break;

}

}

void listc()//輸出課程信息

{

struct couse * p;

p=head1;

printf(“課程編號 課程名稱 學分 課程已選人數 課程人數上限\n”);

while(p!=NULL)

{

printf(“%-8d%10s%6d%8d%12d\n”,p-num1,p-name1,p-score,p-nelepeo,p-Melepeo);

p=p-next;

}

}

void lists()//輸出學生信息

{

struct student * p;

p=head2;

printf(“學生學號 學生姓名 已選課程數量\n”);

while(p!=NULL)

{

printf(“%-4d %10s %6d\n”,p-num2,p-name2,p-nelen);

p=p-next;

}

}

void intoc()//存儲課程信息

{

FILE * fp;

struct couse * p;

char filepath[30];

printf(“輸入課程信息要保存的文件路徑:”);

getchar();

gets(filepath);

if((fp=fopen(filepath,”w”))==NULL)

{

printf(“\n保存失敗!”);

exit(0);

}

p=head1;

while(p!=NULL)

{

fprintf(fp,”%d %s %d %d %d\n”,p-num1,p-name1,p-score,p-nelepeo,p-Melepeo);

p=p-next;

}

fclose(fp);

printf(“課程信息已保存在%s中!\n”,filepath);

}

void intos()//存儲學生信息

{

FILE * fp;

struct student * p;

char filepath[30];

printf(“輸入學生信息要保存的文件路徑:”);

getchar();

gets(filepath);

if((fp=fopen(filepath,”w”))==NULL)

{

printf(“\n保存失敗!”);

exit(0);

}

p=head2;

while(p!=NULL)

{

fwrite(p,sizeof(struct student),1,fp);

p=p-next;

}

fclose(fp);

printf(“學生信息已保存在%s中!\n”,filepath);

}

void into()//存儲信息

{

int i;

printf(“1.存儲課程信息\n”);

printf(“2.存儲學生信息\n”);

printf(“3.返回主菜單\n”);

printf(“請輸入(1~3)\n”);

scanf(“%d”,i);

switch(i)

{

case(1):intoc();break;

case(2):intos();break;

case(3):break;

}

}

void store()//信息主函數

{

int i;

printf(“\t\t系統信息查看及存儲\n”);

printf(“1.查看課程信息\n”);

printf(“2.查看學生信息\n”);

printf(“3.存儲信息\n”);

printf(“4.返回主菜單\n”);

printf(“請輸入(1~4):\n”);

scanf(“%d”,i);

switch(i)

{

case(1):listc();break;

case(2):lists();break;

case(3):into();break;

case(4):break;

}

}

int main()//主函數

{

int i;

start:

printf(“\n\t\t\t歡迎使用學生選課系統!\n”);

printf(“菜單:\n”);

printf(“1.錄入課程信息\n”);

printf(“2.課程管理\n”);

printf(“3.錄入學生信息\n”);

printf(“4.學生信息管理\n”);

printf(“5.學生選課\n”);

printf(“6.系統信息查看及存儲\n”);

printf(“7.退出系統\n”);

printf(“\n請輸入菜單選項(1~7):\n”);

scanf(“%d”,i);

if(i1 || i7)

{

printf(“輸入錯誤,請重輸:\n”);

goto start;

}

switch(i)

{

case(1):

{

system(“cls”);

inputc();

goto start;

break;

}

case(2):

{

system(“cls”);

managementc();

goto start;

break;

}

case(3):

{

system(“cls”);

inputs();

goto start;

break;

}

case(4):

{

system(“cls”);

managements();

goto start;

break;

}

case(5):

{

system(“cls”);

elective();

goto start;

break;

}

case(6):

{

system(“cls”);

store();

goto start;

break;

}

case(7):

{

system(“cls”);

printf(“感謝使用本系統!\n\n再見!\n”);

}

}

return(0);

}

怎樣做一個C語言課程信息管理系統

首先 要定義機構體

然後就是設計函數 也就是系統功能 錄入 查詢 刪除 修改等

switch語句設計菜單

#include stdio.h

#include stdlib.h

#define NULL 0

typedef struct student

{

char clas[20];

char name[20];

char number[20];

int math;

int english;

int computer;

float sum;

float ave;

struct student *next;

}XSSJ;

void freerecord(XSSJ *p)

{

XSSJ *q;

while(p!=NULL)

{

q=p;

p=p-next;

free(q);

}

}

XSSJ *addrecord(XSSJ *p)

{

XSSJ head,*q;

head.next=p;

p=head;

while(p-next!=NULL)

p=p-next;

while(1)

{

char text[80];

q=(XSSJ *)malloc(sizeof(XSSJ));

if(q==NULL)

return(head.next);

q-next=NULL;

printf(“\n請輸入學生的班級、姓名、學號和數學、英語、計算機成績:”);

gets(text);

if(text[0]==’\0′)

break;

sscanf(text,”%s%s%s%d%d%d”,q-clas,q-name,q-number,q-math,q-english,q-computer);

p-next=q;

p=q;

}

return(head.next);

}

XSSJ *createrecord(XSSJ *p)

{

freerecord(p);

return(addrecord(NULL));

}

XSSJ *deleterecord(XSSJ *p)

{

char number[10];

XSSJ *q,head;

printf(“\n請輸入你要刪除的學生學號:\n”);

gets(number);

for(head.next=p,q=head;p!=NULL;p=p-next)

{

if(strcmp(p-number,number)!=0)

q=p;

else

{

q-next=p-next;

free(p);

printf(“\n學號為%s的學生成績已經刪除。\n”,number);

return(head.next);

}

}

printf(“\n沒有學號為%s的學生成績。\n”,number);

return(head.next);

}

void searchrecord(XSSJ *p)

{

char number[10];

printf(“\n請輸入你要查詢的學生學號\n”);

gets(number);

for(;p!=NULL;p=p-next)

{

if(strcmp(p-number,number)==0)

{

printf(“\n班級%s\t姓名%s\t學號%s\t數學%d\t英語%d\t計算機%d\n”,p-clas,p-name,p-number,p-math,p-english,p-computer);

}

}

printf(“\n沒有你要查詢的成績\n”);

}

void displayrecord(XSSJ *p)

{

printf(“\n班級\t姓名\t學號\t數學\t英語\t計算機\t\n”);

for(;p!=NULL;p=p-next)

printf(“\n%s\t%s\t%s\t%d\t%d\t%d\n”,p-clas,p-name,p-number,p-math,p-english,p-computer);

printf(“\n”);

}

void displaymenu() //顯示菜單

{

printf(“\n\n______________菜單___________________\n”);

printf(“1:創建新紀錄\t”);

printf(“2:添加新紀錄\n”);

printf(“3:刪除紀錄 \t”);

printf(“4:查詢紀錄 \n”);

printf(“5:顯示紀錄 \t”);

printf(“0:退出系統 \n”);

printf(“\n請選擇:”);

}

int choiceitem(void)

{

int choice;

char line[80];

do

{

displaymenu();

gets(line);

choice=atoi(line);

}

while(choice0||choice6);

return(choice);

}

void main()

{

XSSJ *head=NULL;

int choice;

do

{

choice=choiceitem();

switch(choice)

{

case 1: head=createrecord(head);

break;

case 2: head=addrecord(head);

break;

case 3: head=deleterecord(head);

break;

case 4: searchrecord(head);

break;

case 5: displayrecord(head);

break;

}

}

while(choice!=0);

printf(“\n\nEND!”);

freerecord(head);

}

hhxy 11tx 06(這個是我的標 不是程序)

這個是我做的 沒有名次排序的功能 我沒有做出來呢 我也剛學這個 希望對你有幫助

c語言學生選修課程管理系統

#include stdio.h

#include stdlib.h

#include string.hstruct student

{

char name[60];

char ID[7];

int score;

};int dq(struct student st[]);

void xianshi();

void bc(struct student st[]);

void add();

void select();

void zz();

void chazhao();

void xhcz();

void xmcz();

void del();

void xmsc();

void xhsc();

void tj();

void px();

void bjg();

void xg();

void xhxg();

void xmxg();

void bca();

void fh();

struct student st[300]; //這個數組用來保存所有的學生信息 和文件裡面的一致

int Number=0; //記錄總的學生人數 也就是數組/文件裡面的學生人數

void main()

{

int choose=0;

FILE *fp=NULL;

char yesorno;

if((fp=fopen(“C://student.dat”,”rb”))==NULL)

{

printf(“\n=========提示:文件不存在,是否要創建一個?(y/n)\n”);

scanf(“%c”,yesorno);

if(yesorno==’y’||yesorno==’Y’)

{

//這裡僅為了建立文件

fp=fopen(“C://student.dat”,”wb”);

fclose(fp);

}

else

exit(0);

}

else

{

Number=dq(st); //要是文件只能夠已經有數據 將數據初始化到數組中

}

system(“cls”);

while(true)

{

xianshi();

printf(“\t\t====請選擇:”);

scanf(“%d”,choose);

system(“cls”);

switch(choose)

{

case 0: exit(0);

//退出

break;

case 1: add();

fh();//增加學生成績

break;

case 2: select();

fh();//查看學生成績

break;

case 3: chazhao();

fh();// 查找

break;

case 4: del();

fh();//刪除

break;

case 5: tj();

fh();//統計

break;

case 6: px();

fh();//排序

break;

case 7: bjg();

fh();//輸出不及格

break;

case 8: xg();

fh();//修改

break;

case 9:zz();

fh();//作者

break;

case 10:bca();

fh();//保存

break;

default:

break;

}

fflush(stdin);

getchar();

system(“cls”);

}

}

void bca()

{

printf(“\t=====程序在運行時已自動保存…..\n”);

}

void fh()

{

printf(“\t===按Enter鍵返回主菜單\n”);

}

void xg() //修改學生信息

{

int way=0;

printf(“請選擇修改查找方式\n”);

printf(“1 按姓名查找修改\n”);

printf(“2 按學號查找修改\n”);

scanf(“%d”,way);

switch(way)

{

case 1: xmxg();

break;

case 2: xhxg();

break;

default: printf(“輸入有誤,結束!\n”);

break;

}

}

//按姓名修改

void xmxg()

{

FILE *fp=NULL;

char name[60];

int i=0;

int changeIndex=0;

int index=0;

printf(“請輸入要修改的學生姓名:”);

scanf(“%s”,name);

for (i=0;iNumber;i++)

{

if (strcmp(name,st[i].name))

{

changeIndex=i; //保存要修改的人的下標

}

break;

}

printf(“\t姓名\t學號\t成績\n”);

printf(“\t%s\t%s\t%d\n\n”,st[changeIndex].name,st[changeIndex].ID,st[changeIndex].score);

printf(“請重新輸入該學生信息”);

printf(“姓名:”);

scanf(“%s”,st[changeIndex].name);

printf(“學號:”);

scanf(“%s”,st[changeIndex].ID);

printf(“成績:”);

scanf(“%d”,st[changeIndex].score); //信息修改後重新更新文件裡面的數據 以保持數據一致性

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

}

void xhxg()//按學號修改

{

FILE *fp=NULL;

char id[60];

int i=0;

int changeIndex=0;

int index=0;

printf(“請輸入要修改的學生學號:”);

scanf(“%s”,id);

for (i=0;iNumber;i++)

{

if (strcmp(id,st[i].ID))

{

changeIndex=i; //保存要修改的人的下標

}

break;

}

printf(“\t姓名\t學號\t成績\n”);

printf(“\t%s\t%s\t%d\n\n”,st[changeIndex].name,st[changeIndex].ID,st[changeIndex].score);

printf(“請重新輸入該學生信息”);

printf(“姓名:”);

scanf(“%s”,st[changeIndex].name);

printf(“學號:”);

scanf(“%s”,st[changeIndex].ID);

printf(“成績:”);

scanf(“%d”,st[changeIndex].score);

//信息修改後重新更新文件裡面的數據 以保持數據一致性

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

printf(“\t=======修改成功\n”);

}void bjg() //輸出不及格人數

{

int i=0;

printf(“以下是不及格:\n”);

printf(“\t姓名\t學號\t成績\n”);

for (i=0;iNumber;i++)

{

if (st[i].score60)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

}

void px()//排序

{

struct student temp;

int wantNUmber=0;

int i=0;

int j=0;

for(i=0;iNumber-1;i++)

{

for(j=i;jNumber-1;j++)

{

if(st[j].scorest[j+1].score)

{

temp=st[j];

st[j]=st[j+1];

st[j+1]=temp;

}

}

}

printf(“你想輸出前幾名的成績:”);

scanf(“%d”,wantNUmber);

if (wantNUmberNumber)

{

wantNUmber=Number;

} printf(“\t姓名\t學號\t成績\n”);

for(i=0;iwantNUmber;i++)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

void tj()//統計

{

int i=0;

double sum=0.0;

for(i=0;iNumber;i++)

{

sum+=st[i].score;

}

printf(“全班總分為:%f\n”,sum);

printf(“平均分為:%f\n”,sum/Number);

}

void del()//刪除

{

int n=0;

printf(“1 按姓名刪除\n”);

printf(“2 按學號刪除\n”);

scanf(“%d”,n);

switch(n)

{

case 1: xmsc();

break;

case 2: xhsc();

break;

}

}

void xmsc()//按姓名刪除

{

FILE *fp=NULL;

char name[60];

int i=0;

int j=0;

printf(“請輸入要刪除的學生姓名:”);

scanf(“%s”,name);

for(i=0;iNumber;i++)

{

if (strcmp(name,st[i].name)==0) //如果查找到就刪除

{

for (j=i;jNumber-1;j++)

{

st[j]=st[j+1];

}

Number–;

}

} //將剩餘數據寫入文件 重新一寫的方式打開文件 把以前的數據擦除了

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

printf(“刪除成功;\n”);

}

void xhsc()//按學號刪除

{

FILE *fp=NULL;

char id[60];

int i=0;

int j=0;

printf(“請輸入要刪除的學生學號:”);

scanf(“%s”,id);

for(i=0;iNumber;i++)

{

if (strcmp(id,st[i].ID)==0) //如果查找到就刪除

{

for (j=i;jNumber-1;j++)

{

st[j]=st[j+1];

}

Number–;

}

}

//將剩餘數據寫入文件 重新一寫的方式打開文件 把以前的數據擦除了

fp=fopen(“C://student.dat”,”wb”);

for (i=0;iNumber;i++)

{

fwrite(st[i],sizeof(struct student),1,fp);

}

fclose(fp);

printf(“刪除成功;\n”);

}

void chazhao()//查找學生

{

int n=0;

printf(“1 按姓名查找\n”);

printf(“2 按學號查找\n”);

scanf(“%d”,n);

switch(n)

{

case 1: xmcz();

break;

case 2: xhcz();

break;

default: printf(“輸入有誤,結束!\n”);

break;

}

}

void xhcz()//按學號查找

{

char id[7];

int i=0;

printf(“請輸入要查找學生學號:”);

scanf(“%s”,id);

system(“cls”);

printf(“\t姓名\t學號\t成績\n”);

for (i=0;iNumber;i++)

{

if (strcmp(id,st[i].ID)==0)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

}

void xmcz()//按姓名查找

{

char name[7];

int i=0;

printf(“請輸入要查找學生姓名:”);

scanf(“%s”,name);

system(“cls”);

printf(“\t姓名\t學號\t成績\n”);

for (i=0;iNumber;i++)

{

if (strcmp(name,st[i].name)==0)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

}

void zz()

{

printf(“\t**********************************************************\n\n”);

printf(“\t^^^^^^^^^^ 武漢工程大學郵電與信息工程學院 ^^^^^^^^^^\n\n”);

printf(“\t^^^^^^^^^ 07網絡與安全管理2班 ^^^^^^^^^\n\n”);

printf(“\t^^^^^^^^ 易樊製作 ^^^^^^^^\n\n”);

printf(“\t^^^^^^^^^ 禁止CTRL+C 謝謝合作 ^^^^^^^^^\n\n”);

printf(“\t^^^^^^^^^^ QQ:895115828\n\n”);

printf(“\t**********************************************************\n\n”);

}

void select()//查看學生

{

int i=0;

printf(“以下是全部學生成績\n”);

printf(“\t姓名\t學號\t成績\n”);

for(i=0;iNumber;i++)

{

printf(“\t%s\t%s\t%d\n”,st[i].name,st[i].ID,st[i].score);

}

}

void add()//增加學生

{

int numberTemp=0;

int i=0;

struct student temp; //臨時保存信息

printf(“請輸入要增加學生成績個數:”);

scanf(“%d”,numberTemp);

for(i=0;inumberTemp;i++)

{

printf(“輸入第%d個同學信息\n”,i+1);

printf(“姓名:”);

scanf(“%s”,temp.name);

printf(“學號:”);

scanf(“%s”,temp.ID);

printf(“成績:”);

scanf(“%d”,temp.score);

st[Number++]=temp; //將剛添加的寫入到數組

bc(temp); //將剛添加的寫入到文件 }

printf(“添加成功\n”);

}

void bc(struct student *st)

{

FILE *fp=NULL;

fp=fopen(“C://student.dat”,”ab+”);

fwrite(st,sizeof(struct student),1,fp);

fclose(fp);

}

int dq(struct student st[])

{

FILE *fp=NULL;

int i=0;

fp=fopen(“C://student.dat”,”rb”);

while(fread(st[i],sizeof(struct student),1,fp))

i++;

fclose(fp);

return i;

}

void xianshi()

{

printf(“\t*****************************************************************\n”);

printf(“\t* *\n”);

printf(“\t* 學生成績管理系統 *\n”);

printf(“\t* *\n”);

printf(“\t* [1] 增加學生成績 [2] 查看學生成績 *\n”);

printf(“\t* [3] 查找學生成績 [4] 刪除學生成績 *\n”);

printf(“\t* [5] 統計(總成績和平均分) [6] 輸出前N名學生成績 *\n”);

printf(“\t* [7] 輸出不及格人數 [8] 修改學生信息 *\n”);

printf(“\t* [9] 關於作者 [10] 保存數據 *\n”);

printf(“\t* [0] 退出系統 *\n”);

printf(“\t*****************************************************************\n”);

}運行成功,請你下去後慢慢研究下這個程序,很簡單的,祝你成功!~

求採納為滿意回答。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/232423.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-11 12:51
下一篇 2024-12-11 12:51

相關推薦

  • 銀行資金管理系統總結

    銀行資金管理系統是銀行日常業務運營的核心支撐系統,主要負責處理銀行的資金流動、結算、清算等業務。本文將從功能特點、技術架構、安全性以及未來發展趨勢等多個方面對銀行資金管理系統進行詳…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • Python數據處理課程設計

    本文將從多個方面對Python數據處理課程設計進行詳細闡述,包括數據讀取、數據清洗、數據分析和數據可視化四個方面。通過本文的學習,讀者將能夠了解使用Python進行數據處理的基本知…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • 北化教務管理系統介紹及開發代碼示例

    本文將從多個方面對北化教務管理系統進行介紹及開發代碼示例,幫助開發者更好地理解和應用該系統。 一、項目介紹 北化教務管理系統是一款針對高校學生和教職工的綜合信息管理系統。系統實現的…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28

發表回復

登錄後才能評論