實驗9 指針1 1、程序填空:下列程序在數組中同時查找最大元素和最小元素的下標,分別存放在 main()函數的max 和 min 變量中。要求:根據運行結果分析程序和填空,並注釋說明填充依據。


//下列程序在數組中同時查找最大元素和最小元素的下標,分別存放在 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);
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM