鱼C论坛

 找回密码
 立即注册
查看: 1469|回复: 5

[已解决]大佬们 帮帮我呗

[复制链接]
发表于 2020-12-18 22:32:58 From FishC Mobile | 显示全部楼层 |阅读模式

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

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

x
给定一个长度为100的整形数组,根据键盘输入的整数n(n<100),往数组中依次读入n个整数,输出其中位数,平均数,众数,结果以double数据格式输出
最佳答案
2020-12-19 10:10:51
本帖最后由 风过无痕1989 于 2020-12-20 15:23 编辑
  1. // 给定一个长度为100的整形数组,根据键盘输入的整数n(n<100),往数组中依次读入n个整数,
  2. // 输出其中位数,平均数,众数,结果以double数据格式输出
  3. #include<stdio.h>
  4. int main()
  5. {
  6.         int i, j, n, temp, temp2,str[2][100];
  7.         double Median, Mean = 0, Mode = 0;
  8.         scanf("%d", &n);

  9.         for (i = 0;i < n;i++)      // 输入 n 个整数
  10.         {
  11.                 scanf("%d", &str[0][i]);
  12.                 str[1][i] = 1;
  13.                 Mean += str[0][i];
  14.         }
  15.         Mean /= n * 1.0;           // 求平均数

  16.         for (i = 0;i < n;i++)      // 对序列str[0]由大至小进行排序
  17.         {
  18.                 for (j = 0;j < n - 1;j++)
  19.                 {
  20.                         if (str[0][j] < str[0][j + 1])
  21.                         {
  22.                                 temp = str[0][j];
  23.                                 str[0][j] = str[0][j + 1];
  24.                                 str[0][j + 1] = temp;
  25.                         }
  26.                 }
  27.         }


  28.         if (n % 2 == 0)            // 求中位数
  29.                 Median = 1.0 * (str[0][n / 2] + str[0][n / 2 - 1]) / 2.0;
  30.         else
  31.                 Median = 1.0 * str[0][n / 2 + 1];

  32.         for (i = 0;i < n;i++)      // 对序列某数出现次数进行查询
  33.         {
  34.                 for (j = 0;j < n;j++)
  35.                 {
  36.                         if (str[0][i] == str[0][j] && i != j)
  37.                                 str[1][i]++;
  38.                 }
  39.         }

  40.         for (i = 0;i < n;i++)      // 对全序列按str[1]由大至小进行排序
  41.         {
  42.                 for (j = 0;j < n - 1;j++)
  43.                 {
  44.                         if (str[1][j] < str[1][j + 1])
  45.                         {
  46.                                 temp = str[1][j];
  47.                                 str[1][j] = str[1][j + 1];
  48.                                 str[1][j + 1] = temp;

  49.                                 temp2 = str[0][j];
  50.                                 str[0][j] = str[0][j + 1];
  51.                                 str[0][j + 1] = temp2;
  52.                         }
  53.                 }
  54.         }

  55.         if (str[1][0] != str[1][1] || str[1][1] != str[1][2])    // 求众数
  56.         {
  57.                 Mode = 1.0 * str[0][0];
  58.         }
  59.        
  60.         printf("Mean = %lf, Median = %lf,", Mean, Median);
  61.         if (Mode != 0)
  62.         {
  63.                 printf(" Mode = %lf", Mode);
  64.         }
  65.         else
  66.         {
  67.                 printf("\n");
  68.                 printf("序列存在多个众数或没有众数,它们位于序列的前面\n");
  69.                 for (i = 0;i < n;i++)
  70.                 {
  71.                         printf("%d ", str[0][i]);
  72.                 }
  73.         }
  74.         printf("\n");
  75. }
复制代码

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-12-19 01:48:52 | 显示全部楼层
本帖最后由 jackz007 于 2020-12-19 02:01 编辑
  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.         int b , d[100] , c , e , i , j , k , n , m , t            ;
  5.         double r1 , r2 , r3                                       ;
  6.         scanf("%d" , & n)                                         ;
  7.         for(i = 0 ; i < n ; i ++) scanf("%d" , & d[i])            ;
  8.         for(i = 0 ; i < n - 1 ; i ++) {
  9.                 for(j = i ; j < n ; j ++) {
  10.                         if(d[j] < d[i]) {
  11.                                 t = d[i]                          ;
  12.                                 d[i] = d[j]                       ;
  13.                                 d[j] = t                          ;
  14.                         }
  15.                 }
  16.         }
  17.         for(m = 0 , k = b = e = d[0] , c = i = 1 ; i < n ; i ++) {
  18.                 k += d[i]                                         ;
  19.                 if(d[i] == e) {
  20.                         c ++                                      ;
  21.                 } else {
  22.                         if(c > m) {
  23.                                 b = e                             ;
  24.                                 m = c                             ;
  25.                         }
  26.                         e = d[i]                                  ;
  27.                         c = 1                                     ;
  28.                 }
  29.         }
  30.         r1 = k * 1.0 / n                                          ;
  31.         r2 = (n % 2) ? d[n / 2] : (d[n / 2 - 1] + d[n / 2]) / 2.0 ;
  32.         r3 = b                                                    ;
  33.         printf("%.2f\t%.2f\t%.2f\n" , r1 , r2 , r3)               ;
  34. }
复制代码

        编译、运行实况
  1. D:\00.Excise\C>cl x.c
  2. 用于 x86 的 Microsoft (R) C/C++ 优化编译器 19.28.29334 版
  3. 版权所有(C) Microsoft Corporation。保留所有权利。

  4. x.c
  5. Microsoft (R) Incremental Linker Version 14.28.29334.0
  6. Copyright (C) Microsoft Corporation.  All rights reserved.

  7. /out:x.exe
  8. x.obj

  9. D:\00.Excise\C>x
  10. 80
  11. 18 20  1  3  5  7  9  2  4  6
  12. 23 25 36  8  7  6  5  4  3  2
  13. 89 88 87 32 33 34 56 67 78 99
  14. 56 77 99 82 84 86 38 48 58 68
  15. 39  3  9  8  5  2  6 18 38 98
  16. 23 25 36  8  7  6  5  4  3  2
  17. 39  3  9  8  5  2  6 18 38 98
  18. 89 88 87 32 33 34 56 67 78 99
  19. 34.84   24.00   2.00

  20. D:\00.Excise\C>
复制代码

最后的结果分别是:平均数、中位数、众数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-19 10:10:51 | 显示全部楼层    本楼为最佳答案   
本帖最后由 风过无痕1989 于 2020-12-20 15:23 编辑
  1. // 给定一个长度为100的整形数组,根据键盘输入的整数n(n<100),往数组中依次读入n个整数,
  2. // 输出其中位数,平均数,众数,结果以double数据格式输出
  3. #include<stdio.h>
  4. int main()
  5. {
  6.         int i, j, n, temp, temp2,str[2][100];
  7.         double Median, Mean = 0, Mode = 0;
  8.         scanf("%d", &n);

  9.         for (i = 0;i < n;i++)      // 输入 n 个整数
  10.         {
  11.                 scanf("%d", &str[0][i]);
  12.                 str[1][i] = 1;
  13.                 Mean += str[0][i];
  14.         }
  15.         Mean /= n * 1.0;           // 求平均数

  16.         for (i = 0;i < n;i++)      // 对序列str[0]由大至小进行排序
  17.         {
  18.                 for (j = 0;j < n - 1;j++)
  19.                 {
  20.                         if (str[0][j] < str[0][j + 1])
  21.                         {
  22.                                 temp = str[0][j];
  23.                                 str[0][j] = str[0][j + 1];
  24.                                 str[0][j + 1] = temp;
  25.                         }
  26.                 }
  27.         }


  28.         if (n % 2 == 0)            // 求中位数
  29.                 Median = 1.0 * (str[0][n / 2] + str[0][n / 2 - 1]) / 2.0;
  30.         else
  31.                 Median = 1.0 * str[0][n / 2 + 1];

  32.         for (i = 0;i < n;i++)      // 对序列某数出现次数进行查询
  33.         {
  34.                 for (j = 0;j < n;j++)
  35.                 {
  36.                         if (str[0][i] == str[0][j] && i != j)
  37.                                 str[1][i]++;
  38.                 }
  39.         }

  40.         for (i = 0;i < n;i++)      // 对全序列按str[1]由大至小进行排序
  41.         {
  42.                 for (j = 0;j < n - 1;j++)
  43.                 {
  44.                         if (str[1][j] < str[1][j + 1])
  45.                         {
  46.                                 temp = str[1][j];
  47.                                 str[1][j] = str[1][j + 1];
  48.                                 str[1][j + 1] = temp;

  49.                                 temp2 = str[0][j];
  50.                                 str[0][j] = str[0][j + 1];
  51.                                 str[0][j + 1] = temp2;
  52.                         }
  53.                 }
  54.         }

  55.         if (str[1][0] != str[1][1] || str[1][1] != str[1][2])    // 求众数
  56.         {
  57.                 Mode = 1.0 * str[0][0];
  58.         }
  59.        
  60.         printf("Mean = %lf, Median = %lf,", Mean, Median);
  61.         if (Mode != 0)
  62.         {
  63.                 printf(" Mode = %lf", Mode);
  64.         }
  65.         else
  66.         {
  67.                 printf("\n");
  68.                 printf("序列存在多个众数或没有众数,它们位于序列的前面\n");
  69.                 for (i = 0;i < n;i++)
  70.                 {
  71.                         printf("%d ", str[0][i]);
  72.                 }
  73.         }
  74.         printf("\n");
  75. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-20 00:25:27 | 显示全部楼层
本帖最后由 jackz007 于 2020-12-20 00:30 编辑

      楼主,用
  1. 80
  2. 18 20  1  3  5  7  9  2  4  6
  3. 23 25 36  8  7  6  5  4  3  2
  4. 89 88 87 32 33 34 56 67 78 99
  5. 56 77 99 82 84 86 38 48 58 68
  6. 39  3  9  8  5  2  6 18 38 98
  7. 23 25 36  8  7  6  5  4  3  2
  8. 39  3  9  8  5  2  6 18 38 98
  9. 89 88 87 32 33 34 56 67 78 99
复制代码

做测试,最佳答案代码给出的结果是
  1. Mean = 34.837500, Median = 18.000000, Mode = 18.000000
复制代码

      输入数据经过排序后是这个样子:
  1. 1  2  2  2  2  2  3  3  3  3
  2. 3  4  4  4  5  5  5  5  5  6
  3. 6  6  6  6  7  7  7  8  8  8
  4. 8  9  9  9 18 18 18 20 23 23
  5. 25 25 32 32 33 33 34 34 36 36
  6. 38 38 38 39 39 48 56 56 56 58
  7. 67 67 68 77 78 78 82 84 86 87
  8. 87 88 88 89 89 98 98 99 99 99
复制代码

      只需要通过肉眼观察,很容易就可以发现,中位数 18 和众数 18 都是错误的!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-20 15:20:32 | 显示全部楼层
jackz007 发表于 2020-12-20 00:25
楼主,用

做测试,最佳答案代码给出的结果是

你给出的9组数据,没有一组是有众数的。

你抢最佳答案,这无可厚非,大家来这里,目的不尽相同,反正我是来学习的。你若真心指出我程序的错误,我很欢迎,也很感激。

我回答这道题目,并非是因为你的程序的正确性,对于你的程序的准确性,我从没有怀疑过,就是见你没有按照题目的要求做。

我第一次发上来时,程序是正确的,后来想将程序排列的整齐一些,直接在网上做了一次修改,没曾想在复制、粘贴时就出了问题。下图是按你提供的数据的第9组输出的(当然,输出时增加了没有众数的可能性)
众数.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-20 15:33:07 | 显示全部楼层
本帖最后由 jackz007 于 2020-12-20 15:35 编辑
风过无痕1989 发表于 2020-12-20 15:20
你给出的9组数据,没有一组是有众数的。

你抢最佳答案,这无可厚非,大家来这里,目的不尽相同,反正 ...


        你回答你的,我回答我的,谁在跟你抢最佳答案,再说了,你的答案正确了吗?我只是指出 "最佳答案" 存在错误而已,至于吗,真是的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-26 20:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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