鱼C论坛

 找回密码
 立即注册
查看: 1320|回复: 4

[已解决]用数组给三个数排序从小到大

[复制链接]
发表于 2019-10-16 18:20:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
怎么用数组给三个数排序从小到大
最佳答案
2019-10-17 12:12:37
其实,最简单的冒泡排序法就很容易了,比如
4,6,2这三个数
先用前两个比较,把大的数6放右边,这里4,6就不用交换了,然后6,2比较,把6放2右边,这一次遍历就把最大的值放右边了,总共遍历N-1次就好,代码如下
int i[10],temp;
for(k = 9;k >0;k--)
{
for(n = 0;n<k;n++)
{
    if(i[n] > i[n+1])
    {
        temp = i[n+1];
        i[n+1] = i[n];
        i[n] = temp;
    }
}
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-10-16 20:17:13 | 显示全部楼层
排序的方法现在的就有很多种。
要用哪种,你可以先了解下,然后再自己敲代码。
参考:
https://blog.csdn.net/mwj327720862/article/details/80498455
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-10-16 21:09:39 | 显示全部楼层
temp = (23,54,23)
num = list(temp)
b = sorted(num)
print(b)

这样,大小就排好啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-10-16 23:07:20 | 显示全部楼层
本帖最后由 bin554385863 于 2019-10-16 23:11 编辑
#include <iostream>
#include <algorithm>
#include <vector>
void _sort()
{
    int n = 1;
    std::cout << "请输入数字的个数" << std::endl;
    std::cin >> n;
    std::vector<int> vec;
    char arg;
    std::cout << "升序请输入l, 降序请输入g" << std::endl;
    std::cin >> arg;
    if (arg != 'l' && arg != 'g')
    {
        std::cout << "参数错误";
        exit(1);
    }
    std::cout << "请输入要排序的数字" << std::endl;
    for (size_t i = 0; i < n; i++)
    {
        int t = 0;
        std::cin >> t;
        vec.push_back(t);
    }
    switch (arg)
    {
    case 'l':
        sort(vec.begin(), vec.end(), std::less<int>()); //升序排序
        break;
    case 'g':
        sort(vec.begin(), vec.end(), std::greater<int>()); //降序排序
    default:
        break;
    }
    for (int i : vec)
    {
        std::cout << i << "  ";
    }
    std::cout << std::endl;
}
int main(int argc, char const *argv[])
{
    _sort();
    return 0;
}
---------------------------------------------------------------------------------------------------------
E:\Users\86184\Documents\Code>c:\Users\86184\.vscode\extensions\ms-vscode.cpptools-0.25.1\debugAdapters\bin\WindowsDebugLauncher.exe --stdin=Microsoft-MIEngine-In-0ukibrgw.dct --stdout=Microsoft-MIEngine-Out-1gtvnay5.w3q --stderr=Microsoft-MIEngine-Error-akvbthh3.ems --pid=Microsoft-MIEngine-Pid-cwckpbd2.ods "--dbgExe=E:\My Program\MinGW\bin\gdb.exe" --interpreter=mi
请输入数字的个数
9
升序请输入l, 降序请输入g
l
请输入要排序的数字
20 36 65 98 10 0 32 56 9
0  9  10  20  32  36  56  65  98


E:\Users\86184\Documents\Code>

评分

参与人数 1鱼币 +3 收起 理由
zwh1481017739 + 3 感谢楼主无私奉献!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2019-10-17 12:12:37 | 显示全部楼层    本楼为最佳答案   
其实,最简单的冒泡排序法就很容易了,比如
4,6,2这三个数
先用前两个比较,把大的数6放右边,这里4,6就不用交换了,然后6,2比较,把6放2右边,这一次遍历就把最大的值放右边了,总共遍历N-1次就好,代码如下
int i[10],temp;
for(k = 9;k >0;k--)
{
for(n = 0;n<k;n++)
{
    if(i[n] > i[n+1])
    {
        temp = i[n+1];
        i[n+1] = i[n];
        i[n] = temp;
    }
}
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-4 15:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表