鱼C论坛

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

[已解决]C语言作业关于步进值的一个小问题

[复制链接]
发表于 2019-9-23 23:08:17 | 显示全部楼层 |阅读模式

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

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

x
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         float pm25[3][12] = {
  5.                 {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 31.3, 35.5, 58.7, 49.6, 55.5},
  6.                 {59.8, 54.9, 33.1, 38.2, 26.6, 20.5, 27.8, 38.5, 41.5, 44.7, 38.1, 41.5},
  7.                 {34.9, 36.4, 47.5, 37.9, 30.6, 23.4, 26.6, 34.3, 0.0, 0.0, 0.0, 0.0}
  8.         };
  9.         int i, j, step;
  10.         float min, max, data;

  11.         // 找出最大值和最小值
  12.         min = max = pm25[1][0];
  13.         for (i = 0; i < 3; i++)
  14.         {
  15.                 for (j = 0; j < 12; j++)
  16.                 {
  17.                         if (pm25[i][j])
  18.                         {
  19.                                 min = min > pm25[i][j] ? pm25[i][j] : min;
  20.                                 max = max < pm25[i][j] ? pm25[i][j] : max;
  21.                         }
  22.                 }
  23.         }

  24.         // 计算步进值                                                                        //我的问题所在
  25.         if ((int)(max - min) > 80)
  26.         {
  27.                 step = 2;
  28.         }
  29.         else
  30.         {
  31.                 step = 1;
  32.         }

  33.         printf("最小值: %.2f, 最大值: %.2f\n", min, max);
  34.         // 打印直方图
  35.         for (i = 0; i < 3; i++)
  36.         {
  37.                 for (j = 0; j < 12; j++)

  38.                 {
  39.                         data = pm25[i][j];
  40.                         if (data)
  41.                         {
  42.                                 printf("%d年%2d月: ", i + 2014, j + 1);
  43.                                 for( ; data >= min; data -= step)                              
  44.                                     printf("*");
  45.                                     
  46.                                 printf("\n");
  47.                         }
  48.                 }
  49.         }

  50.         return 0;
  51. }
复制代码


大佬们,这道题为什么要计算步进值呢,直接在后面执行过程中加1不行吗?另外啥是步进值啊?
那个   if ((int)(max - min) > 80),80是哪来的啊???而且为啥还要有个步进值等于2呢?后面执行过程只需要加1啊


原题:编写一个程序,用户输入待查询年月份(输入格式:2015-03),输出该月份的 PM2.5 值
输出结果: 2019-09-22 (2).png
        
最佳答案
2019-9-23 23:26:44
本帖最后由 jackz007 于 2019-9-23 23:38 编辑

        步进值(step)就是考虑用多少个 '*' 来显示一个 pm25[ i ][j] 的数值,根据下面的代码:
  1.                         data = pm25[i][j]                                      ;
  2. . . . . . .
  3.                                 for( ; data >= min ; data -= step) printf("*") ;
复制代码

        确定用于显示一个 pm25[ i ][j] 数值所应该显示 '*' 个数的计算公式为:
  1.         pm25[i][j] 应该显示的 '*' 字符个数 = (pm25[i][j] - min) / step + 1
复制代码

        合适的 step 值很重要,如果 step 数值过小,那么,显示的 '*' 的数量就可能超过 80,因为 cmd 窗口每列只有 80 个字符位置,如果在同一行显示多于 80 个 '*' ,那直方图就会乱掉;相反,如果 step 数值过大,那么,直方图中 '*' 的数量对 pm25[ i ][j] 的数值变化就会不够敏感,例如,最小值显示出 1 个 '*' ,最大值可能也就显示出 3 个 '*' ,而所有其它的中间数值就只能在 1~3 个 '*' 之间变化, 根本就无法体现出数值变化的层次和细节。
        所以,在代码中,是根据 max - min 的动态变化范围来确定的 step 数值。以便让直方图最大限度突出数据变化的层次和细节。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-9-23 23:26:44 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2019-9-23 23:38 编辑

        步进值(step)就是考虑用多少个 '*' 来显示一个 pm25[ i ][j] 的数值,根据下面的代码:
  1.                         data = pm25[i][j]                                      ;
  2. . . . . . .
  3.                                 for( ; data >= min ; data -= step) printf("*") ;
复制代码

        确定用于显示一个 pm25[ i ][j] 数值所应该显示 '*' 个数的计算公式为:
  1.         pm25[i][j] 应该显示的 '*' 字符个数 = (pm25[i][j] - min) / step + 1
复制代码

        合适的 step 值很重要,如果 step 数值过小,那么,显示的 '*' 的数量就可能超过 80,因为 cmd 窗口每列只有 80 个字符位置,如果在同一行显示多于 80 个 '*' ,那直方图就会乱掉;相反,如果 step 数值过大,那么,直方图中 '*' 的数量对 pm25[ i ][j] 的数值变化就会不够敏感,例如,最小值显示出 1 个 '*' ,最大值可能也就显示出 3 个 '*' ,而所有其它的中间数值就只能在 1~3 个 '*' 之间变化, 根本就无法体现出数值变化的层次和细节。
        所以,在代码中,是根据 max - min 的动态变化范围来确定的 step 数值。以便让直方图最大限度突出数据变化的层次和细节。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-1 06:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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