国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

C語(yǔ)言實(shí)現(xiàn)——學(xué)生管理系統(tǒng)

2019-11-10 17:21:55
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

程序員的必經(jīng)之路吧,學(xué)生管理系統(tǒng)。在制作過(guò)程中體會(huì)到了編寫一個(gè)具體可用的軟件而要做的工作,無(wú)論是編寫前的準(zhǔn)備,還是編寫過(guò)程中每個(gè)細(xì)節(jié)的處理,都讓我理解了這份工作是個(gè)什么樣子。程序并不是抬手就來(lái),一個(gè)軟件要完整,同時(shí)還要將每個(gè)功能部分區(qū)分開(kāi),所以在編寫之前一定要先規(guī)劃清楚,這是一項(xiàng)工程。邏輯要嚴(yán)密,編程完全就是對(duì)邏輯思維的考驗(yàn),大大小小的函數(shù)、語(yǔ)句都是靠邏輯連接起來(lái)的。基礎(chǔ)知識(shí)要扎實(shí),在我現(xiàn)在這個(gè)階段,經(jīng)常會(huì)遇到為干掉bug而苦思半天,在邏輯上尋覓沒(méi)有出口,其實(shí)只是對(duì)用法不了解,上課時(shí)認(rèn)為那種不太??嫉臇|西不用太費(fèi)心,只要把主要的知識(shí)記住就行,但事實(shí)上每個(gè)知識(shí)點(diǎn)都是有用的。

#include<stdio.h>#include<windows.h>//#include<conio.h>//#include<string.h>struct STUDENT {	char name[10];	int num;	int sex;	double score;	struct STUDENT* next;}*ListHead;void menu();void Import();void Show();void Add();void Search();void Rank();void Delete();void Export();void Exit();struct STUDENT* CreatListHead();void ListInsert(char *name,int num,int sex,double score);void IfListBlank();void ExchangeNope(struct STUDENT *p,struct STUDENT *q);void DeleteNode(struct STUDENT *d);void WriteList(char *path);void IfHeadEmpty();int main(){//	Load();//	clrscr();//	PRintf("en");//	system("cls");/*	if(ListHead==NULL)		printf("!!!");	else		printf("???");*/	menu();		return 0;}void menu() {	int i;	system("cls");		printf("-----------------------------------------------/n");	printf("                 學(xué)生管理系統(tǒng)/n");	printf("-----------------------------------------------/n");	printf("       1.導(dǎo)入 | 2.顯示 | 3.增添 | 4.查找/n");	printf("       5.排序 | 6.刪除 | 7.導(dǎo)出 | 8.退出/n");	printf("-----------------------------------------------/n");	printf("請(qǐng)選擇一個(gè)選項(xiàng):");	scanf("%d", &i);	switch(i) {		case 1:Import();break;		case 2:Show();break;		case 3:Add();break;		case 4:Search();break;		case 5:Rank();break;		case 6:Delete();break;		case 7:Export();break;		case 8:Exit();break;		case 9:IfListBlank();break;		default:menu();	}}//導(dǎo)入文件---------------------------------------------------------------------------------void Import(){	ListHead = CreatListHead();	FILE *fp;	char buf[30];	char *iname;	int inum=0;	int isex=0;	double iscore=0;	int i = 0;	char *line;	fp=fopen("students.txt","r");	if(fp==NULL)	{		printf("import failed!&& creat a new file,any key return/n");		ListHead = CreatListHead();		fflush(stdin);		getchar();		menu();	}else{		while(!feof(fp))		{			fgets(buf,30,fp);			line = strtok(buf," /t/r/n");			while(line != NULL)			{				switch(i){				case 0: iname=line; break;				case 1: inum=atoi(line); break;				case 2: isex=atoi(line); break;				case 3: iscore=atof(line); break;				default: break;				}				i++;				//	printf("%s  %d  %d  %f/n",iname,inum,isex,iscore);				//	ListInsert(iname,inum,isex,iscore);				line = strtok(NULL," /t/r/n");				}			i=0;			//	printf("%-10s%-5d %d %4.1f/n",iname,inum,isex,iscore);			ListInsert(iname,inum,isex,iscore);		}		fclose(fp); 	}		printf("import successful! anykey to return/n");	fflush(stdin);	getchar();	menu();}//顯示功能---------------------------------------------------------------------------------void Show(){	IfHeadEmpty();	struct STUDENT *prep,*p;	prep = ListHead;	p = ListHead->next;	while(p)	{		prep = p;		p =p->next;		if(prep->sex)		{			printf("%-10s%-5d 男 %4.1f/n",prep->name,prep->num,prep->score);		}else{			printf("%-10s%-5d 女 %4.1f/n",prep->name,prep->num,prep->score);		}	}	printf("show successful! anykey to return/n");	fflush(stdin);	getchar();	menu();}//添加數(shù)據(jù)---------------------------------------------------------------------------------void Add(){	IfHeadEmpty();	char aname[10];	int anum=0;	int asex=0;	double ascore=0;	printf("enter data:");	fflush(stdin);	scanf("%s%d%d%lf",aname,&anum,&asex,&ascore);//	printf("%s%-5d %d %4.1f/n",aname,anum,asex,ascore);	ListInsert(aname,anum,asex,ascore);		printf("add successful! anykey to return/n");	fflush(stdin);	getchar();	menu();}//查詢功能---------------------------------------------------------------------------------void Search(){	IfHeadEmpty();	struct STUDENT *prep,*p;	prep = ListHead;	p=ListHead->next;	int i;	char sname[10];	int snumsex;	double sscore;	int isfind=0;	//printf("%-10s%-5d %d %4.1f/n",name,num,sex,score);	printf("which methed you choose:1.name 2.num 3.sex 4.score 0.exit/n");	scanf("%d",&i);	switch(i){	case 0:menu();	case 1: 		printf("enter the name you are looking for:");		scanf("%s",sname);		while(p)		{			prep = p;			p = p->next;			if(strcmp(prep->name,sname)==0)			{				printf("%-10s%-5d %d %4.1f/n",prep->name,prep->num,prep->sex,prep->score);				isfind = 1;			}		}		break;	case 2:			printf("enter the num you are looking for:");		scanf("%d",&snumsex);		while(p)		{			prep = p;			p =p->next;			if(prep->num==snumsex)			{				printf("%-10s%-5d %d %4.1f/n",prep->name,prep->num,prep->sex,prep->score);				isfind = 2;			}		}		break;	case 3:		printf("enter the sex you are looking for:");		scanf("%d",&snumsex);		while(p)		{			prep = p;			p =p->next;			if(prep->sex==snumsex)			{				printf("%-10s%-5d %d %4.1f/n",prep->name,prep->num,prep->sex,prep->score);				isfind = 3;			}		}		break;	case 4:		printf("enter the score you are looking for:");		scanf("%lf",&sscore);		while(p)		{			prep = p;			p =p->next;			if(prep->score==sscore)			{				printf("%-10s%-5d %d %4.1f/n",prep->name,prep->num,prep->sex,prep->score);				isfind = 4;			}		}		break;	default:		printf("error number,re-enter:/n");		Search();	}	if(isfind!=0)		printf("Search successful! press any ket to return/n");	else		printf("Search failed! press any ket to return/n");	fflush(stdin);	getchar();//	setbuf(stdin,"4/r");//	ungetc('4',stdin);//	sscanf("4","%d",stdin);//	menu();	Search();}//排序功能---------------------------------------------------------------------------------void Rank(){	IfHeadEmpty();	struct STUDENT *prep,*p,*key;	int i=0,j=1;//	double isequal;//	printf("%-10s%-5d %d %4.1f/n",name,num,sex,score);	printf("sort by: 1.name 2.num 3.sex 4.score 0.exit/n");	scanf("%d",&i);	if(i<1 || i>4)	{		printf("wrong choose,re-enter:/n");		Rank();	}	printf("order: 1.positive 0.reverse/n");	scanf("%d",&j);	if(j<0 || j>1)	{		printf("wrong choose,re-enter:/n");		Rank();	}	switch(i){	case 0:menu();              //選擇排序法:將第一個(gè)數(shù)的備份與后排比較,小于它的就將他賦值給備份交換(指針代表原數(shù)),一行循環(huán)接收進(jìn)行,再將第二個(gè)數(shù)進(jìn)行如此循環(huán)	case 1:			prep = ListHead;		p=ListHead->next;		while(prep->next)		{			prep = prep->next;			p = prep->next;			key = prep;			while(p)			{				if(j)				{					if(strcmp(key->name,p->name) > 0)						key = p;				}else{					if(strcmp(key->name,p->name) < 0)						key = p;				}				p = p->next;			}			ExchangeNope(prep, key);		}		break; 	case 2:		prep = ListHead;		p=ListHead->next;		while(prep->next)		{			prep = prep->next;			p = prep->next;			key = prep;			while(p)			{				if(j)				{					if((key->num-p->num) > 0)						key = p;				}else{					if((key->num-p->num) < 0)						key = p;				}				p = p->next;			}			ExchangeNope(prep, key);		}		break;	case 3:		prep = ListHead;		p=ListHead->next;		while(prep->next)		{			prep = prep->next;			p = prep->next;			key = prep;			while(p)			{				if(j)				{					if((key->sex-p->sex) > 0)						key = p;				}else{					if((key->sex-p->sex) < 0)						key = p;				}				p = p->next;			}			ExchangeNope(prep, key);		}		break;	case 4:		prep = ListHead;		p=ListHead->next;		while(prep->next)		{			prep = prep->next;			p = prep->next;			key = prep;			while(p)			{				if(j)				{					if((key->score-p->score) > 0)						key = p;				}else{					if((key->score-p->score) < 0)						key = p;				}				p = p->next;			}			ExchangeNope(prep, key);		}		break;	default:printf("wrong choose,re-enter:");		Rank();	}	Show();	printf("Rank successful!any key to return;/n");	fflush(stdin);	getchar();	menu();	}//刪除---------------------------------------------------------------------------------void Delete(){	IfHeadEmpty();	struct STUDENT *prep,*p,*del;	prep = ListHead;	p=ListHead->next;	int i;	int isfind=0;	char *dname;	int dnumsex;	double dscore;	printf("select a method: 1.name 2.num 3.sex 4.score 0.exit/n");	scanf("%d",&i);	switch(i){	case 0:menu();	case 1:		printf("enter the name:/n");		scanf("%s",dname);		while(p)		{						if(!strcmp(p->name,dname))			{				prep->next = p->next;				del = p;				printf("%-10s%-5d %d %4.1f(已刪除)/n",del->name,del->num,del->sex,del->score);				free(p);				p = prep->next;				isfind = 1;			}else{				prep = p;				p =p->next;			//	isfind = 0;			}		}		break;	case 2:		printf("enter the num:/n");		scanf("%d",&dnumsex);		while(p)		{						if(!(p->num-dnumsex))			{				prep->next = p->next;				del = p;				printf("%-10s%-5d %d %4.1f(已刪除)/n",del->name,del->num,del->sex,del->score);				free(p);				p = prep->next;				isfind = 1;			}else{				prep = p;				p =p->next;			//	isfind = 0;			}		}		break;	case 3:		printf("enter the sex:/n");		scanf("%d",&dnumsex);		while(p)		{						if(!(p->sex-dnumsex))			{				prep->next = p->next;				del = p;				printf("%-10s%-5d %d %4.1f(已刪除)/n",del->name,del->num,del->sex,del->score);				free(p);				p = prep->next;				isfind = 1;			}else{				prep = p;				p =p->next;			//	isfind = 0;			}		}		break;	case 4:		printf("enter the score:/n");		scanf("%lf",&dscore);		while(p)		{						if(!(p->score-dscore))			{				prep->next = p->next;				del = p;				printf("%-10s%-5d %d %4.1f(已刪除)/n",del->name,del->num,del->sex,del->score);				free(p);				p = prep->next;				isfind = 1;			}else{				prep = p;				p =p->next;			//	isfind = 0;			}		}		break;	default:		printf("wrong choose,re-enter:");		Delete();	}	if(isfind)		printf("Delete successful!/n");	else		printf("Delete failed!/n");	printf("there is the current list:/n");	Show();	fflush(stdin);	printf("press any key to continue");	getchar();	menu();}//導(dǎo)出檔案---------------------------------------------------------------------------------void Export(){	IfHeadEmpty();	FILE *fp;	char save[15];	int i;	printf("enter the save name:/n");	fflush(stdin);///	printf("if wrong????????????????????/n");	scanf("%s",save);                        //字符串鍵入只能用字符串?dāng)?shù)組接收不能用指針變量//	printf("if wrong????????????????????/n");	fp = fopen(save,"r");//	printf("if wrong????????????????????/n");	if(fp!=NULL)	{		printf("Whether covered: 1.Yse 0.No:/n");		fflush(stdin);		scanf("%d",&i);		if(i)			WriteList(save);		else			Export();		fclose(fp);	}else{		WriteList(save);			}			printf("Export successful! press any key to continue");	fflush(stdin);	getchar();	menu();	}//退出-----------------------------------------------------------------------------------------void Exit(){	exit(0);}//鏈表相關(guān)函數(shù)---------------------------------------------------------------------------------struct STUDENT* CreatListHead(){	struct STUDENT* p;	p = (struct STUDENT*)malloc(sizeof(struct STUDENT));//結(jié)構(gòu)體指針創(chuàng)建后一定要初始化?。?!	p->next = NULL;	return p;}void ListInsert(char *name,int num,int sex,double score){	//printf("%-10s%-5d %d %4.1f/n",name,num,sex,score);	struct STUDENT *prep,*p;	prep = ListHead;	p=ListHead->next;	printf("%-10s%-5d %d %4.1f/n",name,num,sex,score);	while(p)	{		prep = p;		p =p->next;	}	p = (struct STUDENT*)malloc(sizeof(struct STUDENT));		strcpy(p->name,name);	p->num = num;	p->sex = sex;	p->score = score;	p->next = NULL;	prep->next = p;}void IfListBlank(){	struct STUDENT *prep,*p;	int i=0;	prep = ListHead;	p=ListHead->next;	while(p)	{		prep = p;		p =p->next;		i++;	}	printf("%d",i);}void ExchangeNope(struct STUDENT *p,struct STUDENT *q){	char exchar[10];	int exint;	double exdouble;	strcpy(exchar , p->name);	strcpy(p->name , q->name);	strcpy(q->name , exchar);	exint = p->num;	p->num = q->num;	q->num = exint;	exint = p->sex;	p->sex = q->sex;	q->sex = exint;	exdouble = p->score;	p->score = q->score;	q->score = exdouble;}void DeleteNode(struct STUDENT *d){	struct STUDENT *prep,*p,*del;	prep = ListHead;	p=ListHead->next;	while(p)	{		if(prep==d)		{			prep->next = p->next;			del = p;			printf("%-10s%-5d %d %4.1f(已刪除)/n",del->name,del->num,del->sex,del->score);			prep = p->next;			p = prep->next;			free(del);			break;		}else{			prep = p;			p =p->next;		}	}}void WriteList(char *path){	struct STUDENT *p;//	prep = ListHead;	p = ListHead->next;	FILE *fpin;	fpin = fopen(path,"w");	while(p)	{	//	fwrite(p,sizeof(p),1,fpin);		fprintf(fpin,"%-10s%-5d %d %4.1f/n",p->name,p->num,p->sex,p->score);		printf("%-10s%-5d %d %4.1f(已寫入)/n",p->name,p->num,p->sex,p->score);		p = p->next;	}	fclose(fpin);}void IfHeadEmpty(){	if(ListHead==NULL){		printf("please import!/n");		getchar();		menu();	}}


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 汉寿县| 德庆县| 敦化市| 昌平区| 平远县| 泸溪县| 临邑县| 丰镇市| 台北市| 方正县| 九龙县| 雅江县| 郎溪县| 龙江县| 团风县| 东莞市| 永春县| 榆社县| 城步| 土默特右旗| 炉霍县| 冕宁县| 钟祥市| 鄂托克前旗| 小金县| 外汇| 平遥县| 望江县| 钦州市| 章丘市| 秭归县| 沾化县| 铜陵市| 图片| 中卫市| 沂水县| 文登市| 岳普湖县| 龙山县| 合水县| 山西省|