当前位置:   article > 正文

数据结构课设------学生管理系统_现有学生成绩信息文件1(1. txt),内容如下 姓名 学号 语文 数学 英语 张明明 01 67

现有学生成绩信息文件1(1. txt),内容如下 姓名 学号 语文 数学 英语 张明明 01 67

学生成绩管理系统

现有学生成绩信息文件1(1.txt),内容如下
姓名 学号 语文 数学 英语
张明明 01 67 78 82
李成友 02 78 91 88
张辉灿 03 68 82 56
王露 04 56 45 77
陈东明 05 67 38 47
…. … … … …
学生成绩信息文件2(2.txt),内容如下:
姓名 学号 语文 数学 英语
陈果 31 57 68 82
李华明 32 88 90 68
张明东 33 48 42 56
李明国 34 50 45 87
陈道亮 35 47 58 77
…. … … … …
试编写一管理系统,要求如下:

  1. 实现对两个文件数据进行合并,生成新文件3.txt
  2. 抽取出三科成绩中有补考的学生并保存在一个新文件4.txt
  3. 对合并后的文件3.txt中的数据按总分降序排序(至少采用两种排序方法实现)
  4. 输入一个学生姓名后,能查找到此学生的信息并输出结果(至少采用两种查找方法实现)
  5. 要求至少使用结构体实现上述要求,若增加其他实现方式更好.
  6. 采用多种方法且算法正确者,可适当加分.

代码

#include <stdio.h>
#include <string.h>

typedef struct
{
	char id[10];
	char name[20];
	char score[10];
}student;

#define N 1024

void menu(int *n)
{
	printf("\t\t\t*********************************************\n");
	printf("\t\t\t\t\t1.查找学生信息\n");
	printf("\t\t\t\t\t2.按成绩进行排序\n");
	printf("\t\t\t\t\t3.合并信息表\n");
	printf("\t\t\t\t\t4.创建补考信息表\n");
	printf("\t\t\t\t\t0.退出\n");
	printf("\t\t\t*********************************************\n");
	printf("请输入操作数0-4:");
	scanf("%d", n);
}//创建菜单

void Printfstudent(student p[N], int len)
{
	int i;
	printf("学号\t\t姓名\t\t分数\n\n");
	for (i = 0; i < len; i++)
	{
		printf("%s\t\t", p[i].id);
		printf("%c%c%c%c%c%c%c%c%c\t\t", p[i].name[0],p[i].name[1],p[i].name[2],p[i].name[3],p[i].name[4],p[i].name[5],p[i].name[6],p[i].name[7],p[i].name[8]);
		printf("%s\t\\t\n", p[i].score);
	}
}

int visit(student p[N],int len,int i)
{
	int k=0;
	while(p[i].score[k] !='\0')
		 k++;
	return k;
}



void Sort(student p[N], int len)
{
	student st;
	int i,j,a,b;	
	for(i=0;i<len-1;i++)
	{
		for(j=0;j<len-1-i;j++)
		{			
			if(strcmp(p[j].score,p[j+1].score) < 0)
			{
			   st = p[j];
			   p[j] = p[j+1];
			   p[j+1] = st;
			}
            a=visit(p,len,j);
			b=visit(p,len,j+1);
			if(a<b)
			{
			   st = p[j];
			   p[j] = p[j+1];
			   p[j+1] = st;
			 
			}
		
			
		}
	}
	Printfstudent(p, len);
}

void serch(student p[N], int len)
{
	int i, j;
	int flat = 0;
	char num[100];
	char name1[100];
	printf("请输入1或2,1按学号查找,2按姓名查找:");
	scanf("%d", &i);
	if (i == 1)
	{
		printf("请输入要查找的学号:");
		scanf(" %s", num);
		for (j = 0; j <len; j++)
		{
			if (strcmp(p[j].id, num) == 0)
			{
				flat++;
				break;
			}
		}
		if ( flat==0 )
		{
			printf("学号出现错误!\n");
		}
		else
		{
			printf("学号: %s,姓名: %c%c%c%c%c%c%c%c%c,得分: %s\n", p[j].id, p[j].name[0],p[j].name[1],p[j].name[2],p[j].name[3],p[j].name[4],p[j].name[5],p[j].name[6],p[j].name[7],p[j].name[8], p[j].score);
		}
	}
	else if (i == 2)
	{
		flat = 0;
		printf("请输入要查找的姓名:");
		scanf(" %s", name1);
		for (j = 0; j <len; j++)
		{
			if (strcmp(p[j].name, name1) == 0)
			{
				flat++;
				printf("学号: %s,姓名: %c%c%c%c%c%c%c%c%c,得分: %s\n", p[j].id, p[j].name[0],p[j].name[1],p[j].name[2],p[j].name[3],p[j].name[4],p[j].name[5],p[j].name[6],p[j].name[7],p[j].name[8], p[j].score);
				break;
			}
		}
		if (!flat)
		{
			printf("姓名输入有误!\n");
		}
	}
}

//文件1.txt的读入
int dos1(student p[N],int len)
{
	int i,k;
	char a[200];
	FILE *fp = fopen("1.txt", "r+");
	if (fp == NULL)
		return 1;
	fgets(a,200,fp);
	fclose(fp);
	i=0; len=0; k=0;
	while (a[i] != '#')
	{
	    while (a[i] != ',')
		{
	    	p[len].id[k]=a[i];
		     i++;k++;			 
		}
        i++; k=0;
	    while (a[i] != ',')
		{
		    p[len].name[k]=a[i];
		    i++; k++;			
		}
		i++; k=0;
		
	    while (a[i] != '&')
		{
		    p[len].score[k]=a[i];
		    i++; k++;			
		}
		i++; k=0; len++;
	}
	
	return len;
}


//文件2.txt的读入
int dos2(student p[N],int len)
{
	int i,k;
	char b[200];
	FILE *fp = fopen("2.txt", "r+");
	if (fp == NULL)
		return 1;
	fgets(b,200,fp);	
	fclose(fp);
	i=0; k=0;
	while ( b[i]!='#')
	{
	    while (b[i] != ',')
		{
	    	p[len].id[k]=b[i];
		     i++;k++;
			 
		}
        i++; k=0;
	    while (b[i] != ',')
		{
		    p[len].name[k]=b[i];
		    i++; k++;
			
		}
		i++; k=0;
	    while (b[i] != '&')
		{
		    p[len].score[k]=b[i];
		    i++; k++;			
		}
		i++; k=0; len++;
	}
	return len;
}

//合并到文件3.txt
void dos3(student p[N],int len)
{
	FILE *fp;
	int i;
	fp=fopen("3.txt","w+");
	for(i=0;i<len;i++)
	{
		fprintf(fp,"%s,%c%c%c%c%c%c%c%c%c,%s &",p[i].id,p[i].name[0],p[i].name[1],p[i].name[2],p[i].name[3],p[i].name[4],p[i].name[5],p[i].name[6],p[i].name[7],p[i].name[8],p[i].score);
	}
	fclose(fp);
}

//将补考的人的名单输出到文件4.txt
void dos4(student p[N],int len)
{
	FILE *fp;
	int i=0,a;
	char b[2]="60";
	fp=fopen("4.txt","w+");
	while(i<len)
	{
		
		a=visit(p,len,i);
		if(a==3) i++;
		else if(strcmp(p[i].score,b) > 0)
			i++;
		else if(strcmp(p[i].score,b) < 0)
		{
			fprintf(fp," %s,%c%c%c%c%c%c%c%c%c,%s &",p[i].id,p[i].name[0],p[i].name[1],p[i].name[2],p[i].name[3],p[i].name[4],p[i].name[5],p[i].name[6],p[i].name[7],p[i].name[8],p[i].score);
			i++;
		}
	}
	fclose(fp);
}

void main()
{
	int n,len;
	student p[N]={0};
	len=dos1(p,len);	
	len=dos2(p,len);	
	while (1)
	{
	menu(&n);
	switch (n)
	{  case 1:serch(p,len);
		   break;
	   case 2:Sort(p,len);               
		   break;
	   case 3:dos3(p,len);
		   printf("合并完成\n");
		   break;
	   case 4:dos4(p,len);
		   printf("创建完成\n");
		   break;
	   case 0:printf("欢迎再次使用.\n");		   
		   break;
	   default:
		   printf("您的输入有误,请重新输入.\n");
		   break;
	}
	}
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217
  • 218
  • 219
  • 220
  • 221
  • 222
  • 223
  • 224
  • 225
  • 226
  • 227
  • 228
  • 229
  • 230
  • 231
  • 232
  • 233
  • 234
  • 235
  • 236
  • 237
  • 238
  • 239
  • 240
  • 241
  • 242
  • 243
  • 244
  • 245
  • 246
  • 247
  • 248
  • 249
  • 250
  • 251
  • 252
  • 253
  • 254
  • 255
  • 256
  • 257
  • 258
  • 259
  • 260
  • 261
  • 262
  • 263
  • 264
  • 265
  • 266
  • 267
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/679481
推荐阅读
相关标签
  

闽ICP备14008679号