java!c! 2023-07-10 13:36 采纳率: 100%
浏览 55
已结题

求一个一维数组的最大元素和最小元素的位置

求一个一维数组的最大元素和最小元素的位置
我设计的思路也比较简单

#include<stdio.h>
int maxstr(int *a)
{
    int i,max=a[0],t;
    for(i=1;i<10;i++)
    {
        if(max<a[i])
    {
        max=a[i];
        t=i;    }
    }
    return t+1;
}
int minstr(int *a)
{
    int i,min=a[0],t;
    for(i=1;i<10;i++)
    {
        if(min>a[i])
        {
            min=a[i];
        t=i;
                }
    }
    return t+1;
}

void main()
{
    int a[10],i,max,min;
    printf("请输入一组(10个为一组)一维数组:");
    for(i=0;i<10;i++)
    scanf("%d",&a[i]);
    max=maxstr(a);
    min=minstr(a);
    printf("最大元素的位置:%d\n最小元素的位置:%d",max,min);
}

为什么输出的两个位置会一样呢

img

  • 写回答

4条回答 默认 最新

  • Lee哈 新星创作者: 前端开发技术领域 2023-07-10 13:46
    关注

    给t赋初始值:

    
    
    #include<stdio.h>
    int maxstr(int *a)
    {
        int i,max=a[0],t=0; //修改的地方 
        for(i=1;i<10;i++)
        {
            if(max<a[i])
        {
            max=a[i];
            t=i;    
        }
        }
        return t+1;
    }
    int minstr(int *a)
    {
        int i,min=a[0],t=0;//修改的地方 
        for(i=1;i<10;i++)
        {
            if(min>a[i])
            {
                min=a[i];
                t=i;
            }
        }
        return t+1;
    }
     
    int main()
    {
        int a[10],i,max,min;
        printf("请输入一组(10个为一组)一维数组:");
        for(i=0;i<10;i++)
        scanf("%d",&a[i]);
        max=maxstr(a);
        min=minstr(a);
        printf("最大元素的位置:%d\n最小元素的位置:%d",max,min);
    }
     
    

    img


    如有帮助给个采纳谢谢

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 7月18日
  • 已采纳回答 7月10日
  • 创建了问题 7月10日