gpt4 book ai didi

c - 如何找到数组中整数和数字之间的两个最接近的差异

转载 作者:太空宇宙 更新时间:2023-11-04 03:40:09 24 4
gpt4 key购买 nike

我的代码的目标是在数组中的数字和整数之间获得两个最接近的差异。这是我的代码。

#include <stdio.h>
int main()
{
int kilometre, exit_gas[7]={90,95,116,150,300,377,677},i,distance;
distance=(kilometre-exit_gas[0]);
printf("Enter your kilometre reading:");
scanf("%d",&kilometre);
for(j=1;j<8;++j){
if(abs(kilometre-exit_gas[j])<distance){
distance=abs(kilometre-exit_gas[j]);
printf("%d\n",distance);
}
}
return 0;
}

我的代码存在问题,它发现数组中所有数字与整数(公里)之间的差异。例如,如果公里为 299,则上述代码的输出为:

204
183
149
1

期望的输出应该是:

149
1

我知道我得到了 204 183因为它们也满足限制 if(abs(kilometre-exit_gas[j])<distance)那么我应该如何修改我的限制以获得所需的结果?

最佳答案

我不明白你是如何得到你帖子中显示的结果的,因为我得到了另一个结果。尽管如此,该程序可以看起来像以下方式。

#include <stdio.h>
#include <stdlib.h>

int main(void)
{
int exit_gas[] = { 90, 95, 116, 150, 300, 377, 677 };
const size_t N = sizeof( exit_gas ) / sizeof( *exit_gas );
size_t i;
int kilometre;
unsigned int first, second;

printf( "Enter your kilometre reading: " );
scanf( "%d", &kilometre );

for ( i = 0; i < N; i++ )
{
unsigned int distance = abs( kilometre - exit_gas[i] );
if ( i == 0 || distance < first )
{
if ( i != 0 ) second = first;
first = distance;
}
else if ( i == 1 || distance < second )
{
second = distance;
}
}

printf( "%u\n", first );
printf( "%u\n", second );

return 0;
}

我的程序的输出是

1
78

关于c - 如何找到数组中整数和数字之间的两个最接近的差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29356136/

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