鱼C论坛

 找回密码
 立即注册
查看: 950|回复: 1

[已解决]为啥会出现一堆乱码?

[复制链接]
发表于 2020-11-16 19:47:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 头发 于 2020-11-16 19:58 编辑
  1. #include <stdio.h>
  2. #define N 16
  3. typedef struct
  4. { char num[10];
  5. int s;
  6. } STREC;
  7. int fun( STREC *a, STREC *b )
  8. {
  9.         int max=0,s=0;                                                //要求编写一个函数
  10.                                                                        //功能:把分数最高的学生数据放在b所指的数组中。注意:分数最高的学生可能不止一个,函数返                                                                                                                                            
  11.         for(int i=0;i<N;i++)                                            回分数最高的学生的人数。
  12.          if(a[i].s>max) max=a[i].s;
  13.         for(int i=0;i<N;i++)
  14.          if(a[i].s==max) s++;
  15.         for(int i=0;i<s;i++)
  16.          b[i].s=max;
  17.         return s;
  18. }
  19. main()
  20. { STREC s[N]={{"GA05",85},{"GA03",76},{"GA02",69},{"GA04",85},
  21. {"GA01",91},{"GA07",72},{"GA08",64},{"GA06",87},
  22. {"GA015",85},{"GA013",91},{"GA012",64},{"GA014",91},
  23. {"GA011",77},{"GA017",64},{"GA018",64},{"GA016",72}};
  24. STREC h[N];
  25. int i,n;
  26. n=fun( s,h );
  27. printf("The %d highest score :\n",n);
  28. for(i=0;i<n; i++)
  29. printf("%s %4d\n",h[i].num,h[i].s);
  30. printf("\n");
  31. }
复制代码

结果对了 看到了仨91 ,其他都是乱码。。。咋改?求解
最佳答案
2020-11-16 20:18:25
  1. #include <stdio.h>
  2. #define N 16
  3. typedef struct
  4. {        char num[10];
  5.         int s;
  6. } STREC;

  7. int fun( STREC *a, STREC *b )
  8. {
  9.         int max=0,s=0;                                                //要求编写一个函数
  10.                                                                        //功能:把分数最高的学生数据放在b所指的数组中。注意:分数最高的学生可能不止一个,函数返                                                                                                                                            
  11.         for(int i=0;i<N;i++)                                            //回分数最高的学生的人数。
  12.                         if(a[i].s>max) max=a[i].s;
  13.                
  14.                         //你光返回了成绩,没有返回学号
  15.                 for(i=0;i<N;i++)
  16.                 {
  17.                         if(a[i].s==max)
  18.                         {
  19.                                 b[s++] = a[i];
  20.                         }
  21.                 }


  22.         return s;
  23. }
  24. int main()
  25. {
  26.         STREC s[N]={{"GA05",85},{"GA03",76},{"GA02",69},{"GA04",85},
  27.                                 {"GA01",91},{"GA07",72},{"GA08",64},{"GA06",87},
  28.                                 {"GA015",85},{"GA013",91},{"GA012",64},{"GA014",91},
  29.                                 {"GA011",77},{"GA017",64},{"GA018",64},{"GA016",72}};
  30.         STREC h[N];
  31.         int i,n;
  32.         n=fun( s,h );
  33.         printf("The %d highest score :\n",n);
  34.         for(i=0;i<n; i++)
  35.                 printf("%s %4d\n",h[i].num,h[i].s);
  36.         printf("\n");
  37.         return 0;
  38. }

复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-16 20:18:25 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. #define N 16
  3. typedef struct
  4. {        char num[10];
  5.         int s;
  6. } STREC;

  7. int fun( STREC *a, STREC *b )
  8. {
  9.         int max=0,s=0;                                                //要求编写一个函数
  10.                                                                        //功能:把分数最高的学生数据放在b所指的数组中。注意:分数最高的学生可能不止一个,函数返                                                                                                                                            
  11.         for(int i=0;i<N;i++)                                            //回分数最高的学生的人数。
  12.                         if(a[i].s>max) max=a[i].s;
  13.                
  14.                         //你光返回了成绩,没有返回学号
  15.                 for(i=0;i<N;i++)
  16.                 {
  17.                         if(a[i].s==max)
  18.                         {
  19.                                 b[s++] = a[i];
  20.                         }
  21.                 }


  22.         return s;
  23. }
  24. int main()
  25. {
  26.         STREC s[N]={{"GA05",85},{"GA03",76},{"GA02",69},{"GA04",85},
  27.                                 {"GA01",91},{"GA07",72},{"GA08",64},{"GA06",87},
  28.                                 {"GA015",85},{"GA013",91},{"GA012",64},{"GA014",91},
  29.                                 {"GA011",77},{"GA017",64},{"GA018",64},{"GA016",72}};
  30.         STREC h[N];
  31.         int i,n;
  32.         n=fun( s,h );
  33.         printf("The %d highest score :\n",n);
  34.         for(i=0;i<n; i++)
  35.                 printf("%s %4d\n",h[i].num,h[i].s);
  36.         printf("\n");
  37.         return 0;
  38. }

复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-5 06:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表