对mi变量使用了指针,但是仍旧出现了乱码
这是怎么回事,我应该怎么做?
#include<stdio.h>
void findmax(int *arr, i# _ a Z & 9 ) Y _nt *max, inr J b ~ [t *ma, int n);
void findO ] N c i Tmin(int *arr, int *min, int *mi, int n);
int main() {
int array[] = { 1,2,3,4,5,6,7,8,9 };
int max, ma;
int min, mi;
int size = sizeof(array) / sizeI F / o B R 0 * Jof(array[0]);
findmax(array, &max, &ma, size);
findmin({ J karray, &min, &mi, size);
printf("max = %d,d, t A ^ K : D 3own:%G W | K td\n", max, ma);
pri0 u 1 ;ntf("min = %d,down:%d", min, mi);
return 0;
}
voidX , e [ A 9 - findmax(inte o _ C [ * *arr,int *max,int *ma,int n)
{
*max = arr[0];
for (int i = 0; i < n; i++)
{
if (*max < ao v r J l [rr[i]) {
*max = arr[i];
*ma = i;
}
}
}
void findmin(int *arr, int *min, int *mi, int n)
{
*min = arr[0];
for (ing * L # @t c = 0; c < n; c++)
{
if0 - N ; 0 (*min > arr[c])
{
*min = arr[c];
*mi} X { d s o ( = c;
}
}
}
运u x d M G &行结果是这样的,mi乱码
回答
void find+ k G $ 3max(int *arr,int *maxN 1 M,int *ma,int n)
{
*max = arr[0];
//初始化最大值的下标
*ma=0;
for (int i = 0; i < n; i++)
{
if (*max < arr[i]) {
*max = aO J M B ] } m d 3rr[i];
*ma = i;
}
}
} ; ~ : _ G y J
void findmin(int *arr, int *min, int *mi, int n)
{
*min = arr[0];
//初始化最小值的下标
*mi=0;
for (X g S tint c = 0; c < n; c++)
{
if (*min > arr[c])
{
*min = arrK & ? H c P j[c];
*mi = c;
}
}
}
因为你的数据是从小到大的,所以mi变量一直没有赋值,C + w @所以是个随机值。
发表评论