三目运算符计算最值问题,萌新求教
#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-30 00:18 编辑
如果 min > pm25[ i ] 为真,那么,就说明当前的 min 比 pm25[ i ] 的值要大,min 还能算最小值吗?当然要被换成 pm25[ i ] 才对了,至于 max 的道理与此类同,还是自己想一想吧。
页:
[1]