zoukankan      html  css  js  c++  java
  • 简单排序(冒泡、插入)

    1、冒泡排序 

    typedef enum Status{
        TRUE=1,
        FALSE=0
    }Status;
    
    /*
    n个元素,执行n-1轮,每一轮确定一个最大或最小值
            每一轮执行多少次?
                第一轮:n-1次
                第二轮:n-2次
                ……
                第i轮:n-i次
    */
    
    void bubbleSort(int * arr,int n)
    {
        int temp,i;
        Status flag;
        for (i=1,flag = TRUE; i<n && flag; ++i)
        {
            flag = FALSE;
            for (int j=0; j<n-i; ++j)
            {
                if (arr[j] > arr[j+1])
                {
                    temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = temp;
                    flag = TRUE;
                }
            }
        }
    }

    2、选择排序 

    void selectSort(int *arr, int n)
    {
        //升序排列
        int min,value;
        for (int i=0; i<n-1; ++i)
        {
            min = i;
            for (int j=i+1; j<n; ++j)
            {
                if (arr[min]>arr[j])
                {
                    min=j;
                }
            }
            if (min != i)
            {
                value = arr[min];
                arr[min] = arr[i];
                arr[i]=value;
            }
        }
    }

    3、插入排序

    void insertSort(int * arr,int n)
    {
        int temp;
        for (int i=1; i<n; ++i)
        {
            int j=i-1;
            temp = arr[i];
            while (temp<arr[j] && j>=0)
            {
                arr[j+1]=arr[j];
                j--;
            }
            arr[j+1] = temp;
        }
    }
  • 相关阅读:
    一些无意间YY的脑瘫题
    回滚莫队
    数论
    专题整理
    模拟赛x+1
    HISKrrr的板子库
    java多线程学习笔记(四)
    java多线程学习笔记(三)
    java多线程学习笔记(二)
    Java多线程学习笔记(一)
  • 原文地址:https://www.cnblogs.com/roger-jc/p/8489527.html
Copyright © 2011-2022 走看看