zoukankan      html  css  js  c++  java
  • 快速排序+归并排序

    class Solution {
    public:
        /**
         * @param A an integer array
         * @return void
         */
        int partion(vector<int>& num,int left,int right)
        {
            int poit=num[left];
            while(left<right)
            {
                while(left<right&&num[right]>=poit)
                right--;
                num[left]=num[right];
                while(left<right&&num[left]<poit)
                left++;
                num[right]=num[left];
            }
            num[left]=poit;
            return left;
        }
        void qsort(vector<int>& num,int left,int right)
        {
            if(left<right)
            {
                int idx=partion(num,left,right);
                qsort(num,left,idx-1);
                qsort(num,idx+1,right);
            }
        }
        void sortIntegers2(vector<int>& A) {
            // Write your code here
            qsort(A,0,A.size()-1);
        }
    };
    

      

    class Solution {
    public:
        /**
         * @param A an integer array
         * @return void
         */
        void merge(vector<int>& num,int left,int median,int right)
        {
            int p1=left,p2=median+1;
            vector<int> vec;
            while(p1<=median&&p2<=right)
            {
                if(num[p1]<num[p2])
                {
                    vec.push_back(num[p1]);
                    p1++;
                }
                else
                {
                    vec.push_back(num[p2]);
                    p2++;
                }
            }
            while(p1<=median)
            {
                vec.push_back(num[p1]);
                p1++;
            }
            while(p2<=right)
            {
                vec.push_back(num[p2]);
                p2++;
            }
            int j=0;
            for(int i=left;i<=right;i++)
            num[i]=vec[j++];
        }
        void msort(vector<int>& num,int left,int right)
        {
            if(left<right)
            {
                int median=(left+right)/2;
                msort(num,left,median);
                msort(num,median+1,right);
                merge(num,left,median,right);
            }
        }
        void sortIntegers2(vector<int>& A) {
            // Write your code here
            msort(A,0,A.size()-1);
        }
    };
    

      

  • 相关阅读:
    正则表达式数据验证
    .NET开发工具
    (收藏)自己觉得好的学习网站 持续更新... ...
    MSSQL获取表结构通用方法
    第一阶段冲刺个人博客07
    第一阶段冲刺个人博客06
    第8周学习进度
    第一阶段冲刺个人博客05
    ”图书馆助手“典型用户和用户场景
    ”图书馆助手“典型用户和用户场景
  • 原文地址:https://www.cnblogs.com/wuxiangli/p/6489010.html
Copyright © 2011-2022 走看看