例题:N名学生的成绩已在主函数中放入一个带头结点的链表结构中,a指向链表的头结点。请编写函数fun,它的功能是:找出学生的最高分,由函数返回。
请勿改动主函数main与其它函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
代码如下:
#include<stdio.h>
#include<stdlib.h>
#define N 5
struct list
{
double s;
struct list*next;
};
typedef struct list STR;
double fun(STR*a)
{
double max;
STR*q=a;
max=a->s;
do
{
if(q->s>max)
max=q->s;
q=q->next;
}while(q!=0);
return max;
}
STR*creat(double*s)
{
STR*a,*p,*q;
int i=0;
a=p=(STR*)malloc(sizeof(STR));
p->s=0;
while(i<N)
{
q=(STR*)malloc(sizeof(STR));
q->s=s[i];
i++;
p->next=q;
p=q;
}
p->next=0;
return a;
}
printlist(STR*a)
{
STR*p;
p=a->next;
printf("head");
do
{
printf("->%2.0f",p->s);
p=p->next;
}
while(p!=0);
printf("\n\n");
}
main()
{
double s[N]={
69,72,85,80,68},max;
STR*a;
FILE*out;
a=creat(s);
printlist(a);
max=fun(a);
printf("max=%6.1f\n",max);
out=fopen("oufile.dat","w");
fprintf(out,"max=%6.1f",max);
fclose(out);
}
输出运行窗口如下:
越努力越幸运!
加油,奥力给!!!