一道c语言问题,求解答,谢谢

某班级学生C语言第一次正考的成绩存于数据文件score.dat中,记录了学生学号、姓名和考试成绩,bk.dat文件中记录了补考学生的学号、姓名和补考成绩,编写程序以链式存... 某班级学生C语言第一次正考的成绩存于数据文件score.dat中,记录了学生学号、姓名和考试成绩,bk.dat文件中记录了补考学生的学号、姓名和补考成绩,编写程序以链式存储结构实现以下要求:
1、对该班级按成绩降序排序并统计成绩平均分及每个分数段的人数,结果写入到result.dat中。
2、再根据补考成绩修改原成绩,修改成绩后仍按成绩降序写在result.dat的后面。成绩修改原则:
1)补考成绩大于等于60,原成绩以60分记;2)补考成绩小于60,取两次成绩中最高值记。
代码如下,帮忙修改一下
http://pan.baidu.com/s/1kTxHctL
展开
 我来答
匿名用户
推荐于2016-05-15
展开全部
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAX 50
typedef struct {
int xh; //学生学号、姓名和考试成绩
char na[MAX];
float cj;
}datatype;

typedef struct Node{
datatype  data;
struct Node* next;
} Seqlist;



void print(Seqlist* l);
void initList(Seqlist  *lp);/*置一个空表*/
void createList(Seqlist  *lp, char strname[]);/*建立成绩顺序表 */
void save(Seqlist  *lp, char strname[]);/*保存学生顺序表到指定文件*/
void sort_cj(Seqlist  *lp);  /*降序排序*/
void average(Seqlist  *lp);  /*算平均分并写入文件 */
void bandscore(Seqlist  *lp);/*划分分数段及写入 */
void changescore(Seqlist  *lp, Seqlist  *bk); /*修改成绩*/

int main()
{
Seqlist  lp, bk;
initList(&lp);  initList(&bk);
createList(&lp, "score.dat");
createList(&bk, "bk.dat");
sort_cj(&lp);
save(&lp, "result.dat");
average(&lp);
bandscore(&lp);
changescore(&lp, &bk);
sort_cj(&lp);
save(&lp, "result.dat");
return 0;
}

/*置一个空表*/
void initList(Seqlist  *lp)
{
lp->next = 0;
lp->data.xh =0;
lp->data.na[0]='\0';
lp->data.cj = 0;
}

void print(Seqlist*l){
Seqlist* p = l->next;
while (p)
{
printf("%d %s %f\n", p->data.xh, p->data.na,p->data.cj);
p = p->next;
}
}
/*建立成绩顺序表 */
void createList(Seqlist  *lp, char strname[])
{
FILE *fp;
int xh;
float cj;
Seqlist*p,*tail=lp;
if ((fp = fopen(strname, "rb")) == NULL)
{
printf("file open error\r\n");
exit(0);
}
while (!feof(fp))
{
p = (Seqlist*)malloc(sizeof(Seqlist));
fscanf(fp, "%d%s%f", &p->data.xh, p->data.na, &p->data.cj);
tail->next = p;
tail = p;


}tail->next = NULL;
 print(lp);
fclose(fp);
}

/*降序排序*/
void sort_cj(Seqlist* head)
{
Seqlist* tail = NULL;
while (tail != head->next)
{
Seqlist* pre = head;
Seqlist* cur = pre->next;
while (cur != tail && cur->next != tail)
{
if (cur->data.cj< cur->next->data.cj)
{
//交换当前节点和后一个节点
pre->next = cur->next;
cur->next = cur->next->next;
pre->next->next = cur;
}
pre = pre->next;
cur = pre->next;
}
tail = cur;
}
}

/*保存学生顺序表到文件(追加)*/
void save(Seqlist *l, char strname[])
{
FILE *fp;
Seqlist *lp= l->next;
int i;
if ((fp = fopen(strname, "ab")) == NULL)
{
printf("file open error\r\n");
exit(0);
}
while (lp){
fprintf(fp, "%d %s %.2f\r\n", lp->data.xh, lp->data.na, lp->data.cj);
lp = lp->next;
}
fprintf(fp, "\r\n");
fclose(fp);
}

/*算平均分并写入文件 */
void average(Seqlist  *l)
{
FILE *fp;
int i,num=0;
Seqlist *lp = l->next;
float s = 0, a;
while (lp){
num++;
s += lp->data.cj;
lp = lp->next;
}
if (num)
a = s / num;
if ((fp = fopen("result.dat", "ab")) == NULL){
printf("file open error\r\n");
exit(0);
}
fprintf(fp, "平均分为%.2f\r\n", a);
fprintf(fp, "\r\n");
fclose(fp);
}

/*分数段及写入 */
void bandscore(Seqlist  *l)
{
FILE *fp;
if ((fp = fopen("result.dat", "ab")) == NULL){
printf("file open error\r\n");
exit(0);
}
Seqlist*lp = l->next;
int i, a = 0, q = 0, w = 0, e = 0, r = 0, t = 0, y = 0;
while (lp){

a = lp->data.cj / 10;
lp = lp->next;
switch (a)
{
case 10:q++; break;
case 9:w++; break;
case 8:e++; break;
case 7:r++; break;
case 6:t++; break;
default:y++; break;
}
}
fprintf(fp, "成绩为100有%d人\r\n", q);
fprintf(fp, "成绩为90~99有%d人\r\n", w);
fprintf(fp, "成绩为80~89有%d人\r\n", e);
fprintf(fp, "成绩为70~79有%d人\r\n", r);
fprintf(fp, "成绩为60~69有%d人\r\n", t);
fprintf(fp, "不及格的有%d人\r\n", y);
fprintf(fp, "\r\n");
fclose(fp);
}


/*修改成绩*/
void changescore(Seqlist  *lp, Seqlist  *bk)
{
int i, j;
Seqlist*la = lp->next, *lb = bk->next;
while (lb){
while (la){
if (lb->data.xh == la->data.xh)
{
if (lb->data.cj >= 60)
la->data.cj = 60;
else if (lb->data.cj > la->data.cj) 
la->data.cj = lb->data.cj;
break;
}
la = la->next;
}
lb = lb->next;
}
print(lp);
}
追问
能用链表写一遍吗?谢谢!
kaixingui2012
2014-12-22 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6128万
展开全部
明天给你结果行不行?
更多追问追答
追问
ok
追答
你把两个.dat文件提供给我一下,我需要这两个文件进行程序测试
百度云共享,发我链接!
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式