有一个班4个学生,5门课程.1、求第1门课程的平均分;2、找出有两门以上课程不及格的

有一个班4个学生,5门课程。1、求第1门课程的平均分;2、找出有两门以上课程不及格的学生,输出他们的学号和全部课程成绩及平均成绩;3、找出平均成绩在90分以上或全部课程成绩在85分以上的学生。分别编写3个函数实现以上3个要求,并用到指针。请写的尽量简单点啊。

#include<stdio.h>
int main()
{
float cour_aver(float (*p)[5],int cour);
int i,j;
float score[4][5];
for(i=0;i<4;i++)
{
printf("Please input 5 scores of student No.%d:",i+1);
for(j=0;j<5;j++)scanf("%f",&score[i][j]);}
printf("\tCour1\tCour2\tCour3\tCour4\tCour5\n");
for(i=0;i<4;i++)
{
printf("No.%d\t",i+1);
for(j=0;j<5;j++)
printf("%.1f\t",score[i][j]);
printf("\n");
}
printf("The average of Course 1 is %.1f .\n",cour_aver(score,0));//第一门课程下标是0,不是1.
return 0;
}
float cour_aver(float (*p)[5],int cour)
{
int i;float sum=0;
for(i=0;i<4;i++)
sum=sum+*(*(p+i)+cour);
return sum/4;
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-11-17
JKCXVHKJ
第2个回答  2013-07-09
#include <stdio.h>
#include <string.h>
#define N 10
int main()
{void input(int [],char name[][8]);
void sort(int [],char name[][8]);
void search(int ,int [],char name[][8]);
int num[N],number,flag=1,c;
char name[N][8];
input(num,name);
sort(num,name);
while (flag==1)
{printf("\ninput number to look for:");
scanf("%d",&number);
search(number,num,name);
printf("continue ot not(Y/N)?");
getchar();
c=getchar();
if (c=='N'||c=='n')
flag=0;
}
return 0;
}
void input(int num[],char name[N][8])
{int i;
for (i=0;i<N;i++)
{printf("input NO.: ");
scanf("%d",&num[i]);
printf("input name: ");
getchar();
gets(name[i]);
}
}
void sort(int num[],char name[N][8])
{ int i,j,min,templ;
char temp2[8];
for (i=0;i<N-1;i++)
{min=i;
for (j=i;j<N;j++)
if (num[min]>num[j])
min=j;
templ=num[i];
strcpy(temp2,name[i]);
num[i]=num[min];
strcpy (name[i],name[min]);
num[min]=templ;
strcpy(name[min],temp2);
}
printf("\n result:\n");
for (i=0;i<N;i++)
printf("\n %5d%10s",num[i],name[i]);
}
void search(int n,int num[],char name[N][8])
{int top,bott,mid,loca,sign;
top=0;
bott=N-1;
loca=0;
sign=1;
if ((n<num[0])||(n>num[N-1]))
loca=-1;
while((sign==1) && (top<=bott))
{mid=(bott+top)/2;
if (n==num[mid])
{loca=mid;
printf("NO. %d , his name is %s.\n",n,name[loca]);
sign=-1;
}
else if (n<num[mid])
bott=mid-1;
else
top=mid+1;
}
if (sign==1 || loca==-1)
printf("%d not been found.\n",n);
}本回答被提问者和网友采纳