C语言:结构体数组与链表区别

题目:学生记录由学号和成绩组成,N名学生的数据已放入主函数中的结构体数组中,请编写函数fun,其功能是:把分数最低的学生数据放入b所指的数组中,注意:分数最低的学生可能不止一个,函数返回分数最低的学生人数。
编译环境:VS2010

#include<stdio.h>
#define N 16
typedef struct
{
    
    
	char num[10];
	int s;
}STREC;
int fun(STREC *a, STREC *b)
{
    
    
 /******begin******/

/******end******/
}
void main()
{
    
    
   STEREC s[N] = {
    
    {
    
    "GA05",85},{
    
    "GA03",76},{
    
    "GA02",69},{
    
    "GA04",85},
               {
    
    "GA01",91},{
    
    "GA07",72},{
    
    "GA08",64},{
    
    "GA06",87},
               {
    
    "GA015",85},{
    
    "GA013",91},{
    
    "GA012",64},{
    
    "GA014",91},
               {
    
    "GA011",91},{
    
    "GA017",64},{
    
    "GA018",64},{
    
    "GA016",72}};
                STREC  h[N];
       int  i,n;
       n=fun( s,h );
       printf("The %d lowest score :\n",n);
       for(i=0;i<n; i++)
               printf("%s  %4d\n",h[i].num,h[i].s);
       printf("\n");
}

答案与解析

1.结构体成员名访问+数组指针

int i, j = 0,min = a[0].s;
for(i = 0;i < N;i++)
	if(min > a[i].s)
		min = a[i].s;
for(i = 0;i < N;i++)
	if(min == a[i].s)
		b[j++] == a[i];
return j;

2.通过指针访问结构体成员

 STREC *p = a;
 int min = p -> s;
 int i, cnt = 0;
 for(i = 0;i < N;i++)
 {
    
        
    if(min > p -> s) min = p -> s;
    p++;
 }
  for(i = 0;i < N;i++)
 {
    
    
      if(a -> s == min)
     {
    
     
	 *b = *a;
	  b++;
	  cnt++;    
     } 
     a++;
 }
return cnt;

PS:此处输入数据时易误写成while(p !=NULL)但是请注意只有链表才能用此类写法,而本题只是一个结构体数组。

猜你喜欢

转载自blog.csdn.net/m0_51354361/article/details/110667128
今日推荐