1

我编写了一个基本程序来查找数组中的最大数并打印它:

#include <stdio.h>

int main(void)
{
    int numbers[] = {3, 5, 12, 1, 4};
    int largest;

    largest = numbers[0];

    for (int i = 0; i < sizeof(numbers) / sizeof(numbers[0]); i++)
    {
        if (largest < numbers[i])
        {
            largest = numbers[i];
        }
    }

    printf("The largest number in the array is %i\n", largest);
}

我需要做什么才能打印而不是The largest number in the array is 12打印The largest number in the array is numbers[2]

4

3 回答 3

4

您将使用索引而不是使用该值:

#include <stdio.h>

int main(void)
{
    int numbers[] = { 3, 5, 12, 1, 4 };
    int largest;

    largest = 0;

    for (int i = 1; i < sizeof(numbers) / sizeof(numbers[0]); i++)
    {
        if (numbers[largest] < numbers[i])
        {
            largest = i;
        }
    }

    printf("The largest number in the array is numbers[%d]\n", largest);
    return 0;
}
于 2021-02-03T21:18:43.927 回答
0

一种方法是跟踪索引

#include <stdio.h>

int main(void)
{
    int numbers[] = {3, 5, 12, 1, 4};
    int largest;
    int index = 0;

    largest = numbers[0];

    for (int i = 0; i < sizeof(numbers) / sizeof(numbers[0]); i++)
    {
        if (largest < numbers[i])
        {
            largest = numbers[i];
            index   = i;
        }
    }

    printf("The largest number in the array is %d at numbers[%d]\n", largest,index);
    return 0;
}
于 2021-02-03T21:18:55.520 回答
0

我会做类似的事情:

#include <stdio.h>

int
main(void)
{
        int numbers[] = {3, 5, 12, 1, 4};
        int *largest = numbers;
        int *end = numbers + sizeof numbers / sizeof *numbers;

        for(int *s = numbers; s < end; s++ ){
                if( *s > *largest) {
                        largest = s;
                }
        }
        printf("The largest number in the array is %d, at position %td\n",
                 *largest, largest - numbers);
}
于 2021-02-03T21:23:34.903 回答