排序

排序

#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] << " ";
    }

}

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 该系列文章主要是记录下自己暑假这段时间的学习笔记,暑期也在实习,抽空学了很多,每个方面的知识我都会另起一篇博客去记...
    Yanci516阅读 12,359评论 6 19
  • 一、 单项选择题(共71题) 对n个元素的序列进行冒泡排序时,最少的比较次数是( )。A. n ...
    貝影阅读 9,295评论 0 10
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,243评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,755评论 0 15
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,293评论 0 2