sususususu 发表于 2022-11-29 23:20:38

三目运算符计算最值问题,萌新求教

#include<stdio.h>
int main()
{
        float pm25={
        {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0,31.3, 35.5, 58.7, 49.6, 55.5},
        {59.8, 54.9, 33.1, 38.2, 26.6, 20.5, 27.8, 38.5, 41.5, 44.7, 38.1, 41.5},
        {34.9, 36.4, 47.5, 37.9, 30.6, 23.6, 34.3, 0.0, 0.0, 0.0, 0.0}
        };
        int i, j, step;
        float min, max, data;
       
        min = max = pm25;
        for (i = 0; i < 3; i++)
        {
                for (j = 0; j < 12; j++)
                {
                        if (pm25)
                        {
                                min = min > pm25 ? pm25 : min;                        //为什么判断最小值要用大于号,判断最大值要用小于号,而且输出结果还正确?我在别处所见都是用小于号判断最小值,用大于号判断最大值,这里有什么特殊之处吗
                                max = max < pm25 ? pm25 : max;
                        }
                }
        }
       
        if ((int)(max-min) > 80)
        {
                step = 2;
        }
        else{
                step = 1;
        }
       
        printf("最小值: %0.2f, 最大值: %0.2f\n", min, max);
       
        for(i = 0; i < 3; i++)
        {
                for(j = 0; j < 12; j++)
                {
                        data = pm25;
                        if (data)
                        {
                                printf("%d年%2d月:", i + 2024, j + 1);
                                while (data >= min)
                                {
                                        printf("*");
                                        data -= step;
                                }
                                printf("\n");
                        }
                }
        }
        return 0;
}

jackz007 发表于 2022-11-29 23:41:38

本帖最后由 jackz007 于 2022-11-30 00:18 编辑

      如果 min > pm25[ i ] 为真,那么,就说明当前的 min 比 pm25[ i ] 的值要大,min 还能算最小值吗?当然要被换成 pm25[ i ] 才对了,至于 max 的道理与此类同,还是自己想一想吧。
页: [1]
查看完整版本: 三目运算符计算最值问题,萌新求教