gpt4 book ai didi

arrays - 如何在不排序的情况下找到数组中最小的数字?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:43:25 24 4
gpt4 key购买 nike

我正在编写一个程序,它在不对数组进行排序的情况下找到数组中的最小数字。输出始终为 0。请解释为什么?

#include<stdio.h>
#include<conio.h>

void main() {
int num[5] = {5, 2, 1, 6, 9}, i, j;
int min = num[0];

for (i=0; i<5; i++) {
if (min > num[i+1]) {
min = num[i+1];
}
}
printf("Smallest number is %d", min);

getch();
}

最佳答案

在这个表达式中:num[i+1] 您试图访问数组外部的元素 - 有效数组索引从零到数组长度减一(即 4 在这种情况下,但 4+1 不在数组中)。

无论如何你不应该硬编码数组长度,而是像这样写你的循环:

for (i = 1; i < num.length; i++) {
if (num[i] < min) {
min = num[i];
}
}

这样它会一直有效,数组的实际长度无关紧要。

关于arrays - 如何在不排序的情况下找到数组中最小的数字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33069688/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com