麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

C語言實現——學生管理系統

2019-11-10 19:53:53
字體:
來源:轉載
供稿:網友

程序員的必經之路吧,學生管理系統。在制作過程中體會到了編寫一個具體可用的軟件而要做的工作,無論是編寫前的準備,還是編寫過程中每個細節的處理,都讓我理解了這份工作是個什么樣子。程序并不是抬手就來,一個軟件要完整,同時還要將每個功能部分區分開,所以在編寫之前一定要先規劃清楚,這是一項工程。邏輯要嚴密,編程完全就是對邏輯思維的考驗,大大小小的函數、語句都是靠邏輯連接起來的。基礎知識要扎實,在我現在這個階段,經常會遇到為干掉bug而苦思半天,在邏輯上尋覓沒有出口,其實只是對用法不了解,上課時認為那種不太常考的東西不用太費心,只要把主要的知識記住就行,但事實上每個知識點都是有用的。

#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("                 學生管理系統/n");	printf("-----------------------------------------------/n");	printf("       1.導入 | 2.顯示 | 3.增添 | 4.查找/n");	printf("       5.排序 | 6.刪除 | 7.導出 | 8.退出/n");	printf("-----------------------------------------------/n");	printf("請選擇一個選項:");	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();	}}//導入文件---------------------------------------------------------------------------------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();}//添加數據---------------------------------------------------------------------------------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();              //選擇排序法:將第一個數的備份與后排比較,小于它的就將他賦值給備份交換(指針代表原數),一行循環接收進行,再將第二個數進行如此循環	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();}//導出檔案---------------------------------------------------------------------------------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);                        //字符串鍵入只能用字符串數組接收不能用指針變量//	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);}//鏈表相關函數---------------------------------------------------------------------------------struct STUDENT* CreatListHead(){	struct STUDENT* p;	p = (struct STUDENT*)malloc(sizeof(struct STUDENT));//結構體指針創建后一定要初始化!!!	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();	}}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩精品羞羞答答 | 久久精品首页 | 少妇一级淫片高潮流水电影 | 日日鲁夜夜视频热线播放 | 嗯~啊~弄嗯~啊h高潮视频 | 中国产一级毛片 | 青久草视频 | 欧美片a| 免费毛片观看 | 成人福利软件 | 全黄性性激高免费视频 | 欧美日韩一 | 91精品国产一区二区三区四区在线 | 麻豆一二区 | 成人免费久久 | 韩毛片| 爱爱视频天天干 | omofun 动漫在线观看 | 精品国产乱码久久久久久久 | 久久精品无码一区二区三区 | 色播视频在线播放 | av成人在线电影 | 国产精品久久久久久久久久久久久久久久 | 91精品国产91久久久久久蜜臀 | 插插操 | 草草视频免费 | 久久久一区二区三区精品 | 国产精品久久久久久久久久iiiii | 国产精品久久久久久久久久东京 | 日本精品视频一区二区三区四区 | 一级黄色片武则天 | 国产色视频在线观看免费 | 中文字幕在线观看免费视频 | 亚洲精品一区二区三区免 | 男女一边摸一边做羞羞视频免费 | 国产伦精品一区二区三区 | 欧美囗交| 97zyz成人免费视频 | 黄色日韩网站 | 欧美激情精品久久久久久久久久 | 欧美成人免费在线视频 |