//下列程序在數組中同時查找最大元素和最小元素的下標,分別存放在 main()函數的max 和 min 變量中. #include <stdio.h> void findByPoint(int *, int, int *, int *); void find(int *a, int n, int max, int min); int main(void) { int max1=0, min1=0, a[]={5,3,7,9,2,0,4,1,6,8}; findByPoint(a,10,&max1,&min1); //a是數組a[],10是數組中的個數,&maxi,&min1是地址 printf("數組a最大和最小元素下標是%d,%d\n", max1, min1); int max2=0, min2=0,b[]={3,4,71,9,2,7,4,2,6,90}; find(b,10,max2,min2); //b是數組b[],10是數組中的個數,max2,min2是地址 printf("數組b最大和最小元素下標是%d,%d\n", max2, min2); return 0; } void findByPoint(int *a, int n, int *max, int *min) { int i; *max=*min=0; for (i = 1; i < n; i++) { if (a[i] > a [*max]) *max=i;//將i的值賦給*max if (a[i] < a [*min]) *min=i; //將i的值賦給*min } } void find(int *a, int n, int max, int min) { int i; for (i = 1; i < n; i++) { if (a[i] > a [max]) max=i; //將i的值賦給max if (a[i] < a [min]) min=i; //將i的值賦給max } printf("數組b最大和最小元素下標是%d,%d\n", max, min); }