The___Shy_ 2020-10-29 21:58 采纳率: 57.1%
浏览 213
已采纳

对数组最大值和最小值的位置互换,求大佬

为什么用Swap(&sum[a],&sum[b])没有用

#include<stdio.h>
int FindMax(int sum[]);
int FindMin(int sum[]);
void Swap(int *x,int *y);
int main(void)
{
    int sum[10];
    int a,b; 
    for(int i=0;i<10;i++)
    {
        printf("input a number:");
        scanf("%d",&sum[i]);
    }
    for(int i=0;i<10;i++)
    {
        printf("%d\t",sum[i]);
    }
    printf("\n");
    a=FindMax(sum);
    b=FindMin(sum);
    Swap(&sum[a],&sum[b]);
    for(int i=0;i<10;i++)
    {
        printf("%d\t",sum[i]);
    }
    return 0;
}
int FindMax(int sum[])
{
    int i,k;
    for(i=0;i<10;i++)
    {
        k=i;
        if(sum[i]>sum[k])
        {
            k=i;
        }
    }
    return k;
}
int FindMin(int sum[])
{
    int i,k;
    for(i=0;i<10;i++)
    {
        k=i;
        if(sum[i]<sum[k])
        {
            k=i;
        }
    }
    return k;
}
void Swap(int *x,int *y)
{
    int temp;
    temp=*x;
    *x=*y;
    *y=temp;
}
  • 写回答

1条回答 默认 最新

  • 智者知已应修善业 2020-10-30 10:17
    关注

    观察过最大最小函数返回?直接观察代码就可知返回一直是相同的。
    修改如下试看

    int FindMin(int sum[])
    {
        int i,k=0;
        for(i=0;i<10;i++)
        {
           // k=i;
            if(sum[i]<sum[k])
            {
                k=i;
            }
        }
        return k;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 组策略中的计算机配置策略无法下发
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写
  • ¥20 Qcustomplot缩小曲线形状问题