栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++选择排序

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++选择排序

如果你已经熟悉了上一节冒泡排序代码 +
讲解,那么这一节对你来说很容易,因为选择排序像是冒牌排序的优化版本,在第二次循环中,它减少了每次比较满足条件后,两个值的交换过程。它直接用一个值存储当前最小值在数组中的下标,让此值作标准值跟待比较的值比较。不多说了,这个看代码更直观。相对于冒泡排序,步骤更少一点,也不需要来回的赋值交换,因此是优化版本的冒泡排序。

#include 
#include 
#include 
using namespace std;

int data[10] = {0, 2, 1, 4, 3, 6, 5, 8, 7, 9};

void swap(int temp_i, int temp_j)
{
    int temp_int = 0;
    temp_int = data[temp_i];
    data[temp_i] = data[temp_j];
    data[temp_j] = temp_int;
    if(temp_j == 9)
    {
        cout << "swap : " << temp_j << " : " << data[temp_j] << " : " << data[0] << endl;
    }
}

void select(int* data) //int data[]
{
    for(int i = 0; i < 10; i++)  //左->右 大->小
    {
        int max_index = i;
        for(int j = i; j < 10; j++)
        {
            if(data[max_index] < data[j])
            {
                max_index = j;
            }
        }
        if(i == 0)
        {
            cout << "第一个最大9: " << max_index << " : " << data[max_index] << endl;
        }
        swap(i, max_index);
    }
}

int main(void)
{
       for(int i = 0; i < 10; i++)
    {
        cout << i << " : " << data[i] << endl;
    }
    select(data);
    for(int i = 0; i < 10; i++)
    {
        cout << i << " : " << data[i] << endl;
    }
    return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/429614.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号