解题思路:
首先判断输入的三个数a,b,c中a和b两个数的大小,将较小的数赋值给a,大的赋值给b,然后再判断a和c两个数的大小,较小的数赋值给a,大的赋值给c,以此来确保a中保存的是a,b,c三个数中最小的那个数,然后再判断b和c的大小,较小的保存在b里边,大的在c里边,最后依次输出a,b,c三个数。此题解题思路十分简单易懂,在排序数量少的情况下是非常常见的一种排序方法,十分适合初学者用来入门学习。

注意事项:
在两个数比较大小的过程中,temp的作用就是用来保存其中一个数字,方便两个数进行交换的,确保本来较大的数保存的是较小的值,本来较小的数,保存的是较大的值。

下面用一个形象的例子进行解释,以便读者理解:

假设有一瓶可乐和一瓶雪碧,现在想要将这两瓶饮料交换一下瓶子(这句话的意思就是把原来装可乐的瓶子装雪碧,原来装雪碧的瓶子装可乐),想要实现这一想法,最容易想到的方法就是先找来一个空瓶子,把可乐倒进空瓶子中,然后再把雪碧倒进原来装有可乐的瓶子中,再把原来空瓶子中的可乐倒进原来装有雪碧的瓶子里。

在这个例子中,空瓶子的作用就相当于是代码中temp的作用。

参考代码:

#include<stdio.h>
int main()
{
    //定义三个变量保存三个数字
    int a,b,c;
    //定义临时变量保存临时数据
    int temp;
    //从键盘接受三个数字
    scanf("%d %d %d",&a,&b,&c);
    //用if判断句依次判断两个数的大小
    if(a>b)
    {
        temp=a;
        a=b;
        b=temp;
    }
    if(a>c)
    {
        temp=a;
        a=c;
        c=temp;
    }
    if(b>c)
    {
        temp=b;
        b=c;
        c=temp;
    }
    //输出排序后的三个数
    printf("%d %d %d ",a,b,c);
    return 0;
}


点赞(0)
 

0.0分

13 人评分

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

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

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

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

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

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

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

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

评论列表 共有 8 条评论

刘陈晨 1年前 回复TA
@刘陈晨 @dotcpp0646081 嗷嗷,谢谢!!
刘陈晨 1年前 回复TA
@刘陈晨 @dotcpp0646081 嗷嗷,谢谢!!
拯救不够优秀的自己 1年前 回复TA
@刘陈晨 printf这个单词你写错了
拯救不够优秀的自己 1年前 回复TA
@刘陈晨 printf那一句中用了一个点,错在了这里
刘陈晨 1年前 回复TA
#include<stdio.h>
int main()
{
    int a,b,c,t;
    scanf("%d %d %d",&a,&b,&c);
    if(a>b)
    {
        t=a;
        a=b;
        b=t;
    }
    if(a>c)
    {
        t=a;
        a=c;
        c=t;
    }
    if(b>c)
    {
        t=b;
        b=c;
        c=t;
    }
    pritnf("%d %d %d".a,b,c);
    return 0;
} 请问为什么我这个不对呀?
Renee 2年前 回复TA
@郁猪猪 int a,b,c,min,mid,max;     scanf("%d %d %d ",&a,&b,&c);     min=a,max=c;     if(a>b||a>c)     {         if(b<c) min=b;         else min=c;     }     if(c<a||c<b)     {         if(a>b) max=a;         else max=b;     }     mid=a+b+c-min-max;     printf("%d %d %d ",min,mid,max);
Renee 2年前 回复TA
@郁猪猪 int a,b,c,min,mid,max;     scanf("%d %d %d ",&a,&b,&c);     min=a,max=c;     if(a>b||a>c)     {         if(b<c) min=b;         else min=c;     }     if(c<a||c<b)     {         if(a>b) max=a;         else max=b;     }     mid=a+b+c-min-max;     printf("%d %d %d ",min,mid,max);
郁猪猪 2年前 回复TA
#include<stdio.h>
#include "string.h"
int main(){
    int a[3],i,min,j,t,k;
    for(i=0;i<3;i++){
        scanf("%d",&a[i]);
    }

    for(i=0;i<3;i++){
        min=i;
        for(j=i;j<3;j++){
            if(a[j]<a[min]){
                min = j;
            }
        }
        if(min!=i){
            t = a[min];
            a[min] = a[i];
            a[i] = t;
        }
    }

    for(i=0;i<3;i++){
        printf("%d ",a[i]);
    }
}

选择排序的一种解法va