zoukankan      html  css  js  c++  java
  • 选择排序

    思想: 简单选择排序是指:对于一个序列A中的元素 A[1] - A[n] ,令 i 从 0 到 n-1 枚举, 进行n 趟操作, 每趟从待排序部分[i,n-1] 中选择最小的元素, 令其余待排序部分的第一个元素a[i] 进行交换,这样元素a[i] ,就会与当前区间[0,i-1] 形成新的有序区间[0,i] 。于是在n 趟操作后,所有元素都有序了。(注:下标问题看你们自己怎么定义的咯)

    #include<iostream>
    #include<stdio.h>
    using namespace std;
    int main(){
        int n,a[25];
        cin >> n;
        for(int i = 0 ; i < n ; i ++)
            cin >> a[i];
        for(int i = 0 ; i < n ; i ++)
        {
            int k = i; // k 变量只需存储下标
            for(int j = i+1 ; j < n ; j ++)
            {
                if(a[j] < a[k])
                {
                    k = j;   // 这地方处理的很精妙,通过下标找对应的值
                }
            }
            
            int temp;
            temp = a[k];
            a[k] = a[i];
            a[i] = temp;
        }
        
        for(int i = 0 ; i < n ; i ++)
        {
            cout << a[i] << " ";
        }
    } 
  • 相关阅读:
    MMU_段式映射
    MMU段式映射(VA -> PA)过程分析
    NOR FLASH驱动程序
    PCB上 如何显示 汉字
    poj1273 Drainage Ditches
    poj2349 Arctic Network
    poj3660 Cow Contest
    poj3259 Wormholes
    poj3159 Candies
    poj1011 Sticks
  • 原文地址:https://www.cnblogs.com/wtzmz/p/13990704.html
Copyright © 2011-2022 走看看