• 排序算法:插入排序,选择排序,冒泡排序


    插入排序

    一般来说,插入排序都采用in-place在数组上实现。具体算法描述如下:
    步骤1: 从第一个元素开始,该元素可以认为已经被排序;
    步骤2: 取出下一个元素,在已经排序的元素序列中从后向前扫描;
    步骤3: 如果该元素(已排序)大于新元素,将该元素移到下一位置;
    步骤4: 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置;
    步骤5: 将新元素插入到该位置后;
    步骤6: 重复步骤2~5。

    img

    //插入排序
        public static int[] insertionSort(int[] array) {
    if (array.length == 0)
        return array;
    int current;
    for (int i = 0; i < array.length - 1; i++) {
        current = array[i + 1];
        int preIndex = i;
        while (preIndex >= 0 && current < array[preIndex]) {
    array[preIndex + 1] = array[preIndex];
    preIndex--;
        }
        array[preIndex + 1] = current;
    }
    return array;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    选择排序

    原理: 首先遍历所有数组,选出最小的放在第一个位置, 第二次遍历剩余数组, 第二小的放在第二位置, 以此类推按照从小到大排列.

    img

    //选择排序
    void swap(int* a, int* b)
    {
    	int tem = *a;
    	*a = *b;
    	*b = tem;
    }
    void SelectSort(int* arr, int n)
    {
    	//保存参与单趟排序的第一个数和最后一个数的下标
    	int begin = 0, end = n - 1;
    	while (begin < end)
    	{
    		//保存最大值的下标
    		int maxi = begin;
    		//保存最小值的下标
    		int mini = begin;
    		//找出最大值和最小值的下标
    		for (int i = begin; i <= end; ++i)
    		{
    			if (arr[i] < arr[mini])
    			{
    				mini = i;
    			}
    			if (arr[i] > arr[maxi])
    			{
    				maxi = i;
    			}
    		}
    		//最小值放在序列开头
    		swap(&arr[mini], &arr[begin]);
    		//防止最大的数在begin位置被换走
    		if (begin == maxi)
    		{
    			maxi = mini;
    		}
    		//最大值放在序列结尾
    		swap(&arr[maxi], &arr[end]);
    		++begin;
    		--end;
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42

    冒泡排序

    左边大于右边交换一趟排下来最大的在右边

    img

    
    //冒泡排序
    void BubbleSort(int* arr, int n)
    {
    	int end = n;
    	while (end)
    	{
    		int flag = 0;
    		for (int i = 1; i < end; ++i)
    		{
    			if (arr[i - 1] > arr[i])
    			{
    				int tem = arr[i];
    				arr[i] = arr[i - 1];
    				arr[i - 1] = tem;
    				flag = 1;
    			}
    		}
    		if (flag == 0)
    		{
    			break;
    		}
    		--end;
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    ————————————————
    版权声明:本文为CSDN博主「双鱼211」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/weixin_50886514/article/details/119045154

  • 相关阅读:
    代码坏味道与重构之注释
    Redis搭建主从同步流程及原理
    大数据在电力行业的应用案例100讲(二十)-数字化场景应用电力计量器具需求分析
    88.(cesium篇)cesium聚合图
    mysql中首字母大写的函数,如何借助MySQL函数将字符串的首字母大写?
    一种基于光强传输方程的散射成像相位恢复仿真研究
    2020 MIT6.s081 Lab: Multithreading
    CentOS修改ssh端口
    算法学习-单调双端队列
    Day112.尚医通:手机验证码登录功能
  • 原文地址:https://blog.csdn.net/aiheshuicxy/article/details/128152832