排序

作者: Bill_Chow | 来源:发表于2016-11-18 20:04 被阅读9次

排序

#include<iostream>
using namespace std;

//bubble sort 冒泡排序就是把小的元素往前调或者把大的元素往后调。冒泡排序是两个相邻的数进行比较,把大的放在后面
void bubbleSort(int a[], int n){
    int i, j,temp;
    for (i = 0; i < n-1; i++){
        //因为没经历一次i 排序后,最大的都会放在了最后,那么已经排序的就不用再比较了,经历i次就已经排好i个数,而减一就是7个数,两两比较就只比较了6次
        for (j = 0; j < n - 1 - i; j++){
            if (a[j]>a[j + 1]){
                temp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = temp;
            }
        }
    }
}

// Select sort 选择排序,在每次排序选择最小的出来,
void SelectSort(int a[], int n){
    int i, j,index,temp,min;
    for ( i = 0; i < n; i++){
        min = a[i];
        index = i;
        // 我把每一次排序的最小元素找出来,把下标标记一下,等这一次排序全部比较过直接把下标index的值跟下标为i的值交换
        for (j = i + 1; j < n; j++){
            // 一开始min的值是a[i],当找到比a[i]的值更小的时候,把min设为当前的a[j]值,然后跟剩余的值进行比较,找到最小的值并用index标记起来
            if (a[j]<min){
                min = a[j];
                index = j;
            }
        }
        // 这里只是为了判断一下上面那个循环又没做,没有做就代表当前a[i]已经是最小的了
        if (index != i){
            temp = a[i];
            a[i] = a[index];
            a[index] = temp;
        }
    }
}

// 插入排序
void insertSort(int a[], int n){
    int i,index,currentValue;
    for (i = 1; i < n; i++){
        if (a[i] < a[i - 1]){
            currentValue = a[i];
            index = i - 1;
            //如果当前元素小于上一个元素,那么元素后移
            while (currentValue < a[index])
            {
                a[index + 1] = a[index];
                index--;
                
            }
            // 把值插入到正确的位置
            a[index+1] = currentValue;
        }
    }
}

// 快速排序
void quickSort(int a[], int low, int high){

    if (low >= high)
    {
        return;
    }
    int first = low;
    int last = high;
    int key = a[first];/*用字表的第一个记录作为枢轴*/

    while (first < last)
    {
        while (first < last && a[last] >= key)
        {
            --last;
        }

        a[first] = a[last];/*将比第一个小的移到低端*/

        while (first < last && a[first] <= key)
        {
            ++first;
        }

        a[last] = a[first];
        /*将比第一个大的移到高端*/
    }
    a[first] = key;/*枢轴记录到位*/
    quickSort(a, low, first - 1);
    quickSort(a, first + 1, high);


}


int main(){
    //int data[] = { 2,44,38,5,47,15,36,26,27,3,46,4,4,19,50,48 };
    int data[] = { 6,2,7,3,8,9 };
    int i, j,length,temp;
    length = sizeof(data) / sizeof(int);
    //insertSort(data, length);
    quickSort(data, 0, length-1);

    for (i = 0; i < length; i++){
        cout << data[i] << " ";
    }

}

上面写了四个排序,分别是冒泡排序,选择排序,快速排序和插入排序,
以及一些个人笔记,以便忘了的时候重新记起,当然还有几个排序,归并,堆,二分。

相关文章

  • 【恋上数据结构与算法二】(一)排序(Sorting)

    排序方法 冒泡排序 选择排序 堆排序 插入排序 归并排序 快速排序 希尔排序 计数排序 基数排序 桶排序 初识排序...

  • 排序-冒泡排序

    排序系列传递门 排序—选择排序排序—快速排序排序—插入排序排序-希尔排序(待完善)排序—归并排序(待完善)排序—基...

  • 排序

    冒泡排序: 冒泡排序 选择排序: 插入排序: 希尔排序: 归并排序: 快速排序: 堆排序: 计数排序: 桶排序: ...

  • Java | 10种排序算法

    冒泡排序 选择排序 插入排序 希尔排序 计数排序 基数排序 堆排序 归并排序 快速排序 桶排序

  • 常见的排序

    冒泡排序: 选择排序: 插入排序: 快速排序: 希尔排序: 归并排序: 堆排序: 计数排序: 桶排序: 基数排序:

  • 002--20200409刷题

    冒泡排序 选择排序 插入排序 希尔排序 归并排序 快速排序 堆排序 计数排序 桶排序 基数排序

  • 排序

    排序 符号:Θ 插入排序 选择排序 堆排序 归并排序 冒泡排序 快速排序 桶排序 基数排序 计数排序 插入排序 插...

  • 排序 -- 选择/插入

    聊聊排序吧 冒泡排序 选择排序 插入排序 快速排序 归并排序 计数排序 桶排序 堆排序 本篇 选择排序与插入排序 ...

  • 前端基础整理 | 算法基础

    排序算法 冒泡排序 选择排序 插入排序 希尔排序 归并排序 堆排序 快速排序

  • Java 常见的 8 种排序算法(内排序)

    排序分类 内部排序 插入排序:直接插入排序、希尔排序 交换排序:冒泡排序、快速排序 选择排序:直接选择排序、堆排序...

网友评论

      本文标题:排序

      本文链接:https://www.haomeiwen.com/subject/ufjspttx.html