最新马氏大王

#include<stdio.h>	
#include<stdlib.h>
#include<string.h>
#define LEN 15		/* 学号和姓名最大字符数,实际请更改*/
#define N 50		/* 最大学生人数,实际请更改*/

int k = 1, n = 0, m = 0;/* n代表当前记录的学生人数*/

//函数声明
void readfile();
void seek();
void modify();
void insert();
void del();
void sort1();
void sort2();
void display();
void save();
void menu();

//结构体保存学生信息
struct student{
	char StudentId[LEN+1];
	char StudentName[LEN+1];
	int StudentAge;
	char StudentSex;
	char subject[LEN+1];
	char phone[LEN+1];
}stu[N],*pa;

//主函数
int main()
{
	while (k)
	{
		menu();
	}
	system("pause");
	return 0;
}

//系统帮助函数
void help()
{
	printf("\n0.欢迎使用系统帮助!\n");
	printf("\n1.初次进入系统后,请先刷新读入所需文件里的学生信息;\n");
	printf("\n2.按照菜单提示键入数字代号;\n");
	printf("\n3.增加学生信息后,切记保存;\n");
	printf("\n4.谢谢您的使用!\n");
	system("pause");
}

//刷新文件
int flush()
{
	char filename[LEN + 1];
	int i = 0;
	printf("请输入要刷新学生信息的文件名:\n");
	scanf("%s", filename);
	pa=stu;
	int j = 0;
	FILE * fp;
	if ((fp = fopen(filename, "r")) == NULL)
	 {	
	 	printf("未找到此文件") ;
		return 0;
	 }
	  for(i=0;!feof(fp);i++)								//把文件中的数据写入结构体中
	{
		fscanf(fp,"%s",&stu[i].StudentId);			
		fscanf(fp,"%s",&stu[i].StudentName);
		fscanf(fp,"%d",&stu[i].StudentAge);
		fscanf(fp,"%s",&stu[i].StudentSex);
		fscanf(fp,"%s",&stu[i].subject);
		fscanf(fp,"%s",&stu[i].phone);
	}
	fclose(fp);	
	n=i-1;
	printf("刷新成功!!!");										//关闭文件
	return i-1;

}

//查找学生信息
void seek() /*查找*/
{
	int i, item, flag;
	char s1[21]; /* 以姓名和学号最长长度+1为准*/
	printf("----------------------\n");
	printf("-----1.按学号查询-----\n");
	printf("-----2.按姓名查询-----\n");
	printf("-----3.退出本菜单-----\n");
	printf("----------------------\n");
	while (1)
	{
		printf("请选择子菜单编号:");
		scanf("%d", &item);
		flag = 0;
		switch (item)
		{
		case 1:
			printf("请输入要查询的学生的学号:\n");
			scanf("%s", s1);
			for (i = 0; i<n; i++)
			if (strcmp(s1,stu[i].StudentId) == 0)
			{
				flag = 1;
				printf("学生学号\t学生姓名\t年龄\t性别\t专业\t电话\n");
				printf("--------------------------------------------------------------------\n");
				printf("%s\t\t%s\t\t%d\t%c\t%s\t%s\t\t\n", stu[i].StudentId,stu[i].StudentName,stu[i].StudentAge,stu[i].StudentSex,stu[i].subject,stu[i].phone);
			}
			if (0 == flag)
				printf("该学号不存在!\n"); break;
		case 2:
			printf("请输入要查询的学生的姓名:\n");
			scanf("%s", s1);
			for (i = 0; i<n; i++)
			if (strcmp(stu[i].StudentName, s1) == 0)
			{
				flag = 1;
				printf("学生学号\t学生姓名\t年龄\t性别\t专业\t电话\n");
				printf("--------------------------------------------------------------------\n");
				printf("%s\t\t%s\t\t%d\t%c\t%s\t%s\t\t\n", stu[i].StudentId,stu[i].StudentName,stu[i].StudentAge,stu[i].StudentSex,stu[i].subject,stu[i].phone);
			}
			if (0 == flag)
				printf("该姓名不存在!\n"); break;
		case 3:return;
		default:printf("请在1-3之间选择\n");
		}
	}
}

//修改学生信息
void modify() /*修改信息*/
{
	int i, item, num = -1;
	char sex1, s1[LEN + 1], s2[LEN + 1],s3[LEN + 1],s4[LEN + 1]; /* 以姓名和学号最长长度+1为准*/
	printf("请输入要要修改的学生的学号:\n");
	scanf("%s", s1);
	for (i = 0; i < n; i++){
		if (strcmp(stu[i].StudentId, s1) == 0)/*比较字符串是否相等*/
		{
			num = i;
			printf("------------------\n");
			printf("----1.修改姓名----\n");
			printf("----2.修改年龄----\n");
			printf("----3.修改性别----\n");
			printf("----4.修改专业----\n");
			printf("----5.修改电话----\n");
			printf("---6.退出本菜单---\n");
			printf("------------------\n");
			while (1)
			{
				printf("请选择子菜单编号:");
				scanf("%d", &item);
				switch (item)
				{
				case 1:
					printf("请输入新的姓名:\n");
					scanf("%s", s2);
					strcpy(stu[num].StudentName, s2);
					break;
				case 2:
					printf("请输入新的年龄:\n");
					scanf("%d", &stu[num].StudentAge);
					break;
				case 3:
					printf("请输入新的性别:\n");
					scanf("%s", &sex1);
					stu[i].StudentSex=sex1;
					break;
				case 4:
					printf("请输入新的专业:\n");
					scanf("%s", s3);
					strcpy(stu[num].subject, s3);
					break;
				case 5:
					printf("请输入新的电话:\n");
					scanf("%s", s4);
					strcpy(stu[num].phone, s4);
					break;
				case 6:	return;
				default:printf("请在1-6之间选择\n");
				}
			}
			printf("修改完毕!请及时保存!\n");
		}
		else if(i+1==n){
			printf("没有该学生学号!!!") ;
		}
	}
}

void sort1()//按学号排序
{
	int i, j, k, *p, *q, s;
	char temp[LEN + 1], ctemp;
	for (i = 0; i<n - 1; i++)
	{
		for (j = n - 1; j>i; j--)
		if (strcmp(stu[j - 1].StudentId, stu[j].StudentId)>0)
		{
			strcpy(temp, stu[j - 1].StudentId);
			strcpy(stu[j - 1].StudentId, stu[j].StudentId);
			strcpy(stu[j].StudentId, temp);
			strcpy(temp, stu[j - 1].StudentName);
			strcpy(stu[j - 1].StudentName, stu[j].StudentName);
			strcpy(stu[j].StudentName, temp);
			ctemp = stu[j - 1].StudentSex;
			stu[j - 1].StudentSex = stu[j].StudentSex;
			stu[j].StudentSex = ctemp;
			p = &stu[j - 1].StudentAge;
			q = &stu[j].StudentAge;
			s = *q;
			*q = *p;
			*p = s;
			/*for (k = 0; k<3; k++)
			{
				ftemp = stu[j - 1].score[k];
				stu[j - 1].score[k] = stu[j].score[k];
				stu[j].score[k] = ftemp;
			}*/
			strcpy(temp, stu[j - 1].subject);
			strcpy(stu[j - 1].subject, stu[j].subject);
			strcpy(stu[j].subject, temp);
			strcpy(temp, stu[j - 1].phone);
			strcpy(stu[j - 1].phone, stu[j].phone);
			strcpy(stu[j].phone, temp);
		}
	}
}

void sort2()//按姓名排序
{
	int i,j,k,*p,*q,s;
	char temp[LEN+1];
	char ctemp; 
	for(i=0;i<n;i++)
	{
		for(j=i+1;j<n;j++)
		{
			if(strcmp(stu[i].StudentName,stu[j].StudentName)>0)
			{
				 strcpy(temp, stu[j - 1].StudentId);
			strcpy(stu[j - 1].StudentId, stu[j].StudentId);
			strcpy(stu[j].StudentId, temp);
			strcpy(temp, stu[j - 1].StudentName);
			strcpy(stu[j - 1].StudentName, stu[j].StudentName);
			strcpy(stu[j].StudentName, temp);
			ctemp = stu[j - 1].StudentSex;
			stu[j - 1].StudentSex = stu[j].StudentSex;
			stu[j].StudentSex = ctemp;
			p = &stu[j - 1].StudentAge;
			q = &stu[j].StudentAge;
			s = *q;
			*q = *p;
			*p = s;
			/*for (k = 0; k<3; k++)
			{
				ftemp = stu[j - 1].score[k];
				stu[j - 1].score[k] = stu[j].score[k];
				stu[j].score[k] = ftemp;
			}*/
			strcpy(temp, stu[j - 1].subject);
			strcpy(stu[j - 1].subject, stu[j].subject);
			strcpy(stu[j].subject, temp);
			strcpy(temp, stu[j - 1].phone);
			strcpy(stu[j - 1].phone, stu[j].phone);
			strcpy(stu[j].phone, temp);
			}
		}
	}
}

//添加学生信息函数
void insert() /*插入函数*/
{
	int i=n, j, flag;
	printf("请输入待增加的学生数:\n");
	scanf("%d", &m);
	if (m > 0){
		do
		{
			flag = 1;
			while (flag)
			{
				flag = 0;
				printf("请输入第%d位学生的学号:\n", i + 1);
				scanf("%s", stu[i].StudentId);
				for (j = 0; j < i; j++)
				{
					if (strcmp(stu[i].StudentId, stu[j].StudentId) == 0)
					{
						printf("该学号已存在,请重新输入!\n");
						flag = 1;
						break;
					}
				}
			}
			printf("请输入第%d个学生的姓名:\n", i+1);
			scanf("%s", stu[i].StudentName);
			printf("请输入第%d个学生的年龄:\n", i+1);
			scanf("%d", &stu[i].StudentAge);
			printf("请输入第%d个学生的性别:\n", i+1);
			scanf(" %c", &stu[i].StudentSex);
			printf("请输入第%d个学生的专业:\n",i+1);
			scanf("%s", &stu[i].subject);
			printf("请输入第%d个学生的电话:\n", i+1);
			scanf("%s", &stu[i].phone);
			if (0 == flag){
				i++;
			}
		} while (i<n+m);
	}
		n+=m;
		printf("学生信息增加完毕!!!\n");
		system("pause");
}

//删除学生信息函数
void del()
{
	int i, j, flag = 0;
	char s1[LEN+1];
	printf("请输入要删除学生的学号:\n");
	scanf("%s", s1);
	for (i = 0; i < n; i++){
		if (strcmp(stu[i].StudentId, s1) == 0){
			flag = 1;
			//要删除学生后面的学生往前移一位
			for (j = i; j < n - 1; j++){
				stu[j] = stu[j + 1];
			}
		}
	}
		//查找失败
		if (0 == flag){
			printf("该学号不存在!!!\n");
		}
		if (1 == flag){
			printf("删除成功!!!");
			//删除成功,学生人数减1
			n--;
		}
		system("pause");
}

//显示全部数据信息
void display()
{
	int i;
	printf("共有%d位学生的信息:\n", n);
	if (0 != n)
	{
		printf("学生学号\t学生姓名\t年龄\t性别\t专业\t电话\n");
		printf("--------------------------------------------------------------------\n");
		for (i = 0; i<n; i++)
		{
			printf("%s\t\t%s\t\t%d\t%c\t%s\t%s\t\t\n", stu[i].StudentId,stu[i].StudentName,stu[i].StudentAge,stu[i].StudentSex,stu[i].subject,stu[i].phone);
		}
	}
	system("pause");
}

void save(){
	int i;
	FILE *fp;
	char filename[LEN + 1];
	printf("请输入要保存的文件名:\n");
	scanf("%s", filename);
	fp = fopen(filename, "w");
	for (i = 0; i < n; i++){
		fprintf(fp, "%s %s %d %c %s %s\n", stu[i].StudentId,stu[i].StudentName,stu[i].StudentAge,stu[i].StudentSex,stu[i].subject,stu[i].phone);
	}
	printf("保存成功!!!\n");
	fclose(fp);
	system("pause");
}

void menu()/* 界面*/
{
	int num;
	printf(" \n\n                    \n\n");
	printf("☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆  \n");
	printf("☆                  学生信息管理系统                    ☆  \n");
	printf("☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n\n");
	printf("  ☆☆★★★★★☆☆☆系统功能菜单☆☆★★★★★☆☆☆    \n");
	printf("     ----------------------   ----------------------      \n");
	printf("     *********************************************        \n");
	printf("     * 0.刷新学生信息    *  * 1.显示当前信息     *        \n");
	printf("     *********************************************        \n");
	printf("     * 2.查询学生信息    *  * 3.修改学生信息     *        \n");
	printf("     *********************************************        \n");
	printf("     * 4.增加学生信息    *  * 5.删除学生信息     *        \n");
	printf("     *********************************************        \n");
	printf("     * 6.按学号排序      *  * 7.按姓氏排序       *        \n");
	printf("     *********************************************        \n");
	printf("     * 8.保存当前学生信息*  * 9.退出系统         *        \n");
	printf("     *********************************************        \n");
	printf("     ----------------------   ----------------------      \n");
	printf("请选择菜单编号:");
	scanf("%d", &num);
	switch (num)
	{
	case 0:flush();    break;
	case 1:display();  break;
	case 2:seek();     break;
	case 3:modify();   break;
	case 4:insert();   break;
	case 5:del()   ;   break;
	case 6:sort1();    break;
	case 7:sort2();    break;
	case 8:save();     break;
	case 9:
		k = 0; 
		printf("即将退出程序!\n");
		break;
	default:printf("请在0-9之间选择\n");
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值