有三个学生,每个学生有四门学科的成绩,要求找出其中有不及格科目的学生,输出他的全部成绩。
(按这个程序执行,只能输出一名有不及格学科的学成绩)
#include
int main()
{float score[][4]={{23,68,90,72},{23,90,92,93},{23,78,65,65}};
int i;
float * t;
float search(float (*p)[4],int i);
for(i=0;i<=2;i++)
{ t=search(score,i);
if(t==score[i])
{for(i=0;i<=3;i++)
printf("%5.2f\t",(t+i));}}
return 0;
}
float search(float(*p)[4],int i)
{float *a;
int n;
for(n=0,a=NULL;n<=3;n++)
if((*(p+i)+n)<60)
a=*(p+i);
return a;
}
你这个问题应该是这样的,你的int i 的作用范围是整个main 函数,所以当你的第一层循环开始第一次的时候i = 0;但进入第二层的时候循环了4次,此时的i = 3;然后再去执行第一层循环,这时i= 3已经不满足i<=2这条件了,直接退出 所以你只看到了输出一个学生,你的那个搜素函数写的没问题,而且向这种2维的数组访问会用指针去访问会在以后带来很多方便,鼓励这样写,并不是向楼上说的把程序复杂了,这种模块化思想很好
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。