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日

悬赏问题

  • ¥30 电脑误删了手机的照片怎么恢复?
  • ¥15 (标签-python|关键词-char)
  • ¥15 python+selenium,在新增时弹出了一个输入框
  • ¥15 苹果验机结果的api接口哪里有??单次调用1毛钱及以下。
  • ¥20 学生成绩管理系统设计
  • ¥15 来一个cc穿盾脚本开发者
  • ¥15 CST2023安装报错
  • ¥15 使用diffusionbert生成文字 结果是PAD和UNK怎么办
  • ¥15 有人懂怎么做大模型的客服系统吗?卡住了卡住了
  • ¥20 firefly-rk3399上启动卡住了