解题思路:
输入10个数;

先找到最小数与第一个数交换;

再找到最大数与最后一个交换;

输出交换后的十个数,每个后面带空格;


注意事项:
不可以同时找到最大数和最小数然后一起交换

有同学问为什么不可以,先找到最小最大,在一次性交换,原因如下

如输入数据: 10  1  2  3有

min=1,对应下标为 1   ;max=10对应下标为0

先与第一个数交换后为:1   10    2   3  ,但是注意此时正确max下标变成了1

继续按照之前记录的max下标0进行交换,即变成1与3交换,与实际10与3交换不相符,所以出错



参考代码:

#include <stdio.h>

void deal( int a[] );


int main()
{
    int x[10];
    for ( int i = 0; i < 10; i++ )
        scanf( "%d", &x[i] );

    deal( x );

    return(0);
}


void deal( int a[] )
{
    int max = 0, x, team, l, min = a[0];

    for ( int i = 0; i < 10; i++ )    //找最小数,交换
    {
        if ( a[i] < min )
        {
            min = a[i]; l = i;
        }
    }
    team    = a[0];
    a[0]    = min;
    a[l]    = team;
    for ( int k = 0; k < 10; k++ )     //找最大数,交换
    {
        if ( a[k] > max )
        {
            max = a[k]; x = k;
        }
    }
    team    = a[9];
    a[9]    = max;
    a[x]    = team;

    for ( int j = 0; j < 10; j++ )  //输出
        printf( "%d ", a[j] );
}

别忘点赞哦-.-

点赞(66)
 

0.0分

104 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 68 条评论

lantern 4月前 回复TA
@刘陈晨 因为最小值如果是0,那假如数组中最小值为1,那你的最小值就是0了,但是最大值无所谓,最大值设为0,假如数组中最大值为其他,肯定会被替换掉,假如数组中最大值为0,那就不用变了
lantern 4月前 回复TA
@Jayden 你可以遍历一遍数组找出最大值和最小值,然后再找出这两个数在数组的位置,交换一下位置就行了
lantern 4月前 回复TA
@Jayden 注意读题,不是排序,是把最大的那个放在a[9]的位置,最小的放在a[0]位置,其他的不动,我运行了你的代码,你的完全排序了
Jayden 10月前 回复TA
@Jayden 哪个小哥哥可以给我解释一下呀,谢谢
Jayden 10月前 回复TA
#include<stdio.h>
void input(int a[])
{
    for(int i = 0; i < 10; i ++)
    {
        scanf("%d ", &a[i]);
    }
}
int sort(int a[], int b[], int c)
{
    for(int i = 0; i < 10; i++)
    {
        c = 0;
        for(int j = 0; j < 10; j ++)
        {
            if(a[i] > a[j])
            {
                c ++;
            }
        }
        b[c] = a[i];
    }
}
void output(int b[])
{
    for(int j = 0; j < 10; j ++)
    {
        printf("%d ", b[j]);
    }
}
int main()
{
	int a[101] = {0};
	int b[101] = {0}, c = 0;
	input(a);
	sort(a, b, c);
	output(b);
	return 0;
}
第二个测试点过不了,帮我看看为只有50分呀?
如果我是低阶你会爱我吗 1年前 回复TA
@uq_68577944886 哥哥,one函数return a[i];就能返回这整个数组吗,不太理解
愿祥FIRM 1年前 回复TA
@czhang 噢哟,我知道了
愿祥FIRM 1年前 回复TA
@czhang 为什么不能同时找,
刘陈晨 1年前 回复TA
为什么max=0,而min=a[0]
uq_68577944886 1年前 回复TA
@uq_68577944886 按照题目写了三个函数