数组(C指针)的最大值和最小值


#include<stdio.h>
void find(int a[], int n, int *min, int *max){
int tmp, i, j;
for(i = 0; i < n; i++){
for(j = i + 1; j < n; j++){
if(a[i] < a[j]){
tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
}
}
*max = *a;
*min = *(a + n);

}
int main(){
int a[100];
int n, *min, *max;
printf("husnegtiinn elementiin toog oruul: ");
scanf("%d", &n);
for(int i = 0; i < n; i++){
scanf("%d", &a[i]);
}
find(a, n, min, max);
printf("ih ni : %d nbaga ni : %d", *max, *min);

}

我试图从用户排序数组,并在这些指针中获得最小和最大值。我很难弄清楚如何通过函数传递指针。我遗漏了什么吗?

  • *(a + n)在数组中初始化的元素之外。*(a + n - 1)(或者更简单的a[n-1]))是你赋值的最后一个元素。
  • minmax不应该是int*s,而应该是ints。

例子:

#include<stdio.h>
void find(int a[], int n, int *min, int *max){
if(n < 1) return;
for(int i = 0; i < n; i++){
for(int j = i + 1; j < n; j++){
if(a[i] < a[j]){
int tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
}
}
*max = a[0];
*min = a[n - 1]; // the last element

}
int main(){
int a[100];
int n, min, max; // corrected types
printf("husnegtiinn elementiin toog oruul: ");
if(scanf("%d", &n) != 1 || n < 1 || n > 100) return 1;
for(int i = 0; i < n; i++){
scanf("%d", &a[i]);
}
find(a, n, &min, &max); // take the addresses of `min` and `max`
printf("ih ni : %d nbaga ni : %d", max, min);
}

最新更新