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

        昨日写完冒泡排序,和大多数人的感觉一样,太简单,丝毫没有挑战性。但楼主是一个追求踏实平稳的人,希望地基坚固,也为方便后面学习和研究更加高深的算法。但在研究效率上还有待提高,楼主一定好好努力。今天将会写完选择排序 和 插入排序,本文主在选择排序。

    一. 算法描写叙述

        选择排序:比方在一个长度为N的无序数组中,在第一趟遍历N个数据,找出当中最小的数值与第一个元素交换,第二趟遍历剩下的N-1个数据,找出当中最小的数值与第二个元素交换......第N-1趟遍历剩下的2个数据,找出当中最小的数值与第N-1个元素交换,至此选择排序完毕。

    以以下5个无序的数据为例:

    56 12 80 91 20(文中仅细化了第一趟的选择过程)

    第1趟:12 56 80 91 20


    第2趟:12 20 80 91 56

    第3趟:12 20 56 91 80

    第4趟:12 20 56 80 91

    二. 算法分析

    平均时间复杂度:O(n2)

    空间复杂度:O(1)  (用于交换和记录索引)

    稳定性:不稳定 (比方序列【5, 5, 3】第一趟就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面)

    三. 算法实现

    //交换data1和data2所指向的整形
    void DataSwap(int* data1, int* data2)
    {
    	int temp = *data1;
    	*data1 = *data2;
    	*data2 = temp;
    }
    
    /********************************************************
    *函数名称:SelectionSort
    *參数说明:pDataArray 无序数组;
    *		   iDataNum为无序数据个数
    *说明:    选择排序
    *********************************************************/
    void SelectionSort(int* pDataArray, int iDataNum)
    {
    	for (int i = 0; i < iDataNum - 1; i++)    //从第一个位置開始
    	{
    		int index = i;
    		for (int j = i + 1; j < iDataNum; j++)    //寻找最小的数据索引 
    			if (pDataArray[j] < pDataArray[index])
    				index = j;
    
    		if (index != i)    //假设最小数位置变化则交换
    			DataSwap(&pDataArray[index], &pDataArray[i]);
    	}
    }



  • 相关阅读:
    loj#6074. 「2017 山东一轮集训 Day6」子序列(矩阵乘法 dp)
    loj#6073. 「2017 山东一轮集训 Day5」距离(费用流)
    洛谷P5108 仰望半月的夜空(后缀数组)
    二次剩余Cipolla算法学习笔记
    BZOJ5118: Fib数列2(二次剩余)
    BZOJ3122: [Sdoi2013]随机数生成器(BSGS)
    loj#2531. 「CQOI2018」破解 D-H 协议(BSGS)
    noi.ac #289. 电梯(单调队列)
    51nod“省选”模测第二场 C 小朋友的笑话(线段树 set)
    HDU 4770 Lights Against DudelyLights
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/4200500.html
Copyright © 2011-2022 走看看