我正在尝试编写一个程序,该程序用 11 个点填充数组,随机数在 1-100 之间。似乎随机的东西有效,最小的东西有效,但最大的我得到了疯狂的高数字,这些数字甚至不是数组中被扔掉的 11 个数字的一部分。
不太确定问题是什么,但我很确定这是我过去看到的简单得离谱的事情。
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main( void )
{
int i = 0;
int a[11];
int min = a[0];
int max = a[0];
srandom( (unsigned) time(NULL) );
for (i=0;i<11;i++)
{
a[i]=random( ) % 100 ;
printf("%dn", a[i]);
if (a[i] > max)
{
max = a[i];
}
else if (a[i] < min)
{
min = a[i];
}
}
printf("Min: %dn", min);
printf("Max: %dn", max);
return ( 0 ) ;
}
输出:
16
28
27
58
8
53
76
35
27
19
41
Min: 8
Max: 152908968
为非常高的值..将max初始化为0;
int max = 0;
这是固定代码:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main( void )
{
int i = 0;
int a[11];
int min = 0;
int max = 0;
srandom( (unsigned) time(NULL) );
a[0]=random( ) % 100 ;
min = a[0];
for (i=1;i<11;i++)
{
a[i]=random( ) % 100 ;
printf("%dn", a[i]);
if (a[i] > max)
{
max = a[i];
}
if (a[i] < min)
{
min = a[i];
}
}
printf("Min: %dn", min);
printf("Max: %dn", max);
return 0;
}
输出:
Notra:Desktop Sukhvir$ ./try
82
91
33
8
60
48
60
6
59
62
60
Min: 6
Max: 91
你的问题就在这里:
int a[11];
int min = a[0];
int max = a[0];
您正在使用a[0]
来初始化min
并max
,然后再初始化a[0]
本身。
初始化a[0]
,然后将min
和max
设置为其值,然后从那里继续。
首先,你用垃圾值初始化min
和max
,然后将它们与数组的其他元素进行比较?
-
首先为数组的每个元素赋值。
-
将最小值和最大值设置为 a[0](为简单
起见)。 - 然后开始将max与数组的其他元素进行比较。
请尝试以下代码:
int main( void )
{
int i = 0;
int a[11];
int min;
int max;
srandom( (unsigned) time(NULL) );
for (i=0;i<11;i++)
a[i]=random( ) % 100 ;
min = a[0];
max = a[0];
for (i=1;i<11;i++)
{
printf("%dn", a[i]);
if (a[i] > max)
{
max = a[i];
}
else if (a[i] < min)
{
min = a[i];
}
}
printf("Min: %dn", min);
printf("Max: %dn", max);
return ( 0 ) ;
问题是你的代码片段
int min = a[0];
int max = a[0];
在初始化 a
的元素之前,将a[0]
分配给max
和min
。首先初始化数组的元素,然后可以将其元素分配给其他变量。
int min ;
int max ;
srandom( (unsigned) time(NULL) );
min = max = a[0] = random() % 100 + 1;
for (i = 1; i < 11; i++)
{
a[i]=random( ) % 100 + 1; // to generate numbers between 1 to 100
...
只是为了替代方案,因为您已经得到了 4 个正确答案。
为了初始化变量min
和max
,您可以:
- 初始化它们以获取 a[0] 的值(在 a[0] 收到其值 ;) 之后)。 将最小值初始化为
- 0,将最大值初始化为 100,因为您知道您的值不能小于 0 或大于 100。
- 在测试中添加一个额外的条件:
if (i == 0 || a[i] > max)
并从 0 开始循环。
我提供的另外两种替代方案允许您处理数据尚不可用的情况。例如,如果值来自用户或网络或其他任何内容。
//Just another version...
void minArray(int v[])
{
int m=100,len=0; //for max, put m=0
for(int i=0;v[i];i++)
len++;
for(int i=0;i<len;i++)
if(v[i]<m) //for max, change '<' to '>'
m=v[i];
printf("%d",m);
}
int main(void)
{
int v[100]={5,2,3,4,22,5};
minArray(v);
return 0;
}
你的问题在于最小值和最大值。您正在为它们分配您不知道的值。您正在用大于 0 和小于 100 的值填充数组。那么,为什么不将最小值设置为 100,将最大值设置为 0。这样每当程序找到大于或小于最小值或最大值的数字时。该程序将更改其值。
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main( void )
{
int i = 0;
int a[11];
int min = 100;
int max = 0;
srandom( (unsigned) time(NULL) );
for (i=0;i<11;i++)
{
a[i]=random( ) % 100 ;
printf("%dn", a[i]);
if (a[i] > max)
{
max = a[i];
}
else if (a[i] < min)
{
min = a[i];
}
}
printf("Min: %dn", min);
printf("Max: %dn", max);
return ( 0 ) ;
}
输出:
gcc version 4.6.3
36
47
42
64
21
78
66
23
44
20
95
Min: 20
Max: 95