【发布时间】:2017-09-29 21:53:26
【问题描述】:
我没有得到正确的价值观,我错过了什么?我的另一台 PC 上有类似的代码,它似乎可以工作。已经分析了几个小时,据我所见,一切看起来都很好,但我肯定错过了一些东西。 我得到最大数量 = 22,最大位置 = 0,最小数量 = 22,最小位置 = 2
#include <stdio.h>
int findMaxPos(int *numbers, int length);
int findMinPos(int *numbers, int length);
int findMax(int *numbers, int length);
int findMin(int *numbers, int length);
int main()
{
int arr[] = { 100, 50, 20, 35 , 25, 22};
printf("Max number = %d\nMax pos = %d\nMin number = %d\nMin position = %d", findMax(arr, 6), findMaxPos(arr, 6), findMin(arr, 6), findMinPos(arr, 6));
getchar();
return 0;
}
int findMaxPos(int *numbers, int length) {
int maxPos = 0;
for (int i = 0; i < length; i++)
{
if (numbers[i] > numbers[maxPos])
maxPos = i;
}
return maxPos;
}
int findMinPos(int *numbers, int length)
{
int minPos = 0;
for (int i = 0; i < length; i++)
{
if (numbers[i] < numbers[minPos])
minPos = i;
}
return minPos;
}
int findMax(int *numbers, int length) {
int maxNr = numbers[0];
for (int i = 0; i < length; i++)
{
if (numbers[i] > maxNr);
maxNr = numbers[i];
}
return maxNr;
}
int findMin(int *numbers, int length)
{
int minNr = numbers[0];
for (int i = 0; i < length; i++)
{
if (numbers[i] < minNr);
minNr = numbers[i];
}
return minNr;
}
【问题讨论】:
-
看看那个额外的分号:
if (numbers[i] < minNr);有效地表示:如果数字小于当前的最小值。数字,什么都不做。