ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

算法-快速排序

2021-10-23 11:04:17  阅读:141  来源: 互联网

标签:index arr int 算法 indexMax array 排序 快速 change


算法-快速排序

1.数组array,和整数num,把小于等于num的数放在数座左边,大于num的数放在数组右边。要求额外空间复杂度O(1),时间复杂度O(N)

 public void CodeShow()
        {
            int[] arr={1,3,5,2,3,2,3,4,2,3,1,4};
            int num=3;
​
            int index=0;
            int change=0;
            for (int i = 0; i < arr.Length; i++)
            {
                if(arr[i]<=num){
                    change=arr[i];
                    arr[i]=arr[index];
                    arr[index]=change;
                    index++;                   
                }
            }
            for(int i=0;i<arr.Length;i++)
            {
              Console.WriteLine("结果:{0}",arr[i]);
            }        
        }

2.上一个数组要求左边小于num,中间等于num,右侧大于num。(荷兰国旗问题)

  
 public void CodeShow_2()
        {
            int[] arr={1,3,5,2,3,2,3,4,2,3,1,4};
            int num=3;
​
            int indexMin=0;
            int indexMax=arr.Length-1;
            int change=0;
​
            for (int i = 0; i <= indexMax; i++)
            {
                if (arr[i]<num)
                {
                    change=arr[i];
                    arr[i]=arr[indexMin];
                    arr[indexMin]=change;
                    indexMin++;
                    continue;
                }
                if (arr[i]>num)
                {
                    change=arr[i];
                    arr[i]=arr[indexMax];
                    arr[indexMax]=change;
                    indexMax--;
                    i--;
                }
            }
            for(int i=0;i<arr.Length;i++)
            {
              Console.WriteLine("结果:{0}",arr[i]);
            }     
        }

3.数组arr ,快速排序。

方法一:

public void CodeShow_3()
        {
            int[] arr={1,3,5,2,3,2,3,4,2,3,1,4};
           
            sorting(ref arr,0,arr.Length-1);
​
            for(int i=0;i<arr.Length;i++)
            {
              Console.WriteLine("---------结果:{0}",arr[i]);
            }     
​
        }
​
​
        public void sorting(ref  int[] array,int l ,int r)
        {
            if(l>=r)return;
            int m= process(ref array,l,r);        
            sorting(ref array,l,m-1);
            sorting(ref array,m+1,r);
        }    
        protected int process(ref int[] array,int l ,int r)
        {            
            int indexMin=l;
            int indexMax=r-1;
            int change=0;
            int index=l;
​
            while (index<=indexMax)
            {
                if (array[index]<=array[r])
                {
                    change=array[index];
                    array[index]=array[indexMin];
                    array[indexMin]=change;
​
                    indexMin++;
                    index++;
                    continue;
                }
                if (array[index]>array[r])
                {
                    change=array[index];
                    array[index]=array[indexMax];
                    array[indexMax]=change;
                    indexMax--;
                    //index++;
                }
            }
                   change=array[r];
                    array[r]=array[indexMin];
                    array[indexMin]=change;
            return indexMin;
        }

快速排序方法二:

 public void  CodeShow_4()
        {
            int[] arr={1,3,5,2,3,2,3,4,2,3,1,4};
           
            sorting2(ref arr,0,arr.Length-1);
​
            ShowArr(arr);   
         
        }
        public void sorting2(ref  int[] array,int l ,int r)
        {
            if(l>=r)return;
            int[] m= process2(ref array,l,r);                
            sorting2(ref array,l,m[0]-1);
            sorting2(ref array,m[1]+1,r);
        }    
       protected int[] process2(ref int[] array,int l ,int r)
        {            
            int indexMin=l;
            int indexMax=r-1;
            int change=0;
            int index=l;
​
            while (index<=indexMax)
            {
                if (array[index]<array[r])
                {
                    change=array[index];
                    array[index]=array[indexMin];
                    array[indexMin]=change;
​
                    indexMin++;
                    index++;
                    continue;
                }
                if (array[index]>array[r])
                {
                    change=array[index];
                    array[index]=array[indexMax];
                    array[indexMax]=change;
                    indexMax--;
                    //index++;
                }
                if(array[index]==array[r])
                {
                    index++;
​
                }
            }
                   change=array[r];
                    array[r]=array[indexMax+1];
                    array[indexMax+1]=change;
            return  new  int[2]{indexMin,indexMax+1};
        }

方法三:方法一和二中比较数都是arr[r] ,将r位置变为随机位置,可降低复杂度。

标签:index,arr,int,算法,indexMax,array,排序,快速,change
来源: https://blog.csdn.net/qq_35673663/article/details/120918042

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有