解题思路:

先从后面向前走,找到比5小的放前面,再从前面向后走,找到比5大的放后面,直到L=R;

输入数字       5      2          3        7     9      1      6      4    8

      L






     R
步骤1:

  4

   用4取代

   

2
3
7
9
1
6


发现4<5,R走到这里,这里已经留空

8
步骤2:4
2
3
发现7>5,R走一步,现在是L走到这里9
1
6

   7

    7填空

8
步骤3:4
2
3

1

    1填空

9
发现1<5,L走完,现在R走到这里6
7
8
步骤4:4
231发现9>5,R走完,现在是L走到这里

9

   9填空

678
步骤5:4
2
3
1

5

把5放这里

9
6
7
8

得到:4 2 3 1 5 9 6 7 8   再这样下去





注意事项:看不懂去B站  https://www.bilibili.com/video/BV1nr4y1P7d6?share_source=copy_web





参考代码:

#include<bits/stdc++.h>
using namespace std;
int get_mid(int arr[],int left,int right)
{
	int pivot=arr[left];
	while(left<right)
	{
		while(arr[right]>pivot&&left<right)
		right--;
		arr[left]=arr[right];
		while(arr[left]<=pivot&&left<right)
		left++;
		arr[right]=arr[left];
	}
	arr[left]=pivot;
	return left;
}
void quick_sort(int arr[],int left,int right)
{
	if(left<right)
	{
		int mid=get_mid(arr,left,right);
		quick_sort(arr,left,mid-1);
		quick_sort(arr,mid+1,right);
	}
}
int main()
{
	int n,i,a[100000];
	scanf("%d",&n);
	for(i=0;i<n;i++)
	{	
	    scanf("%d",&a[i]); 
    }
    quick_sort(a,0,n-1);
    for(i=0;i<n;i++)
    {
	    printf("%d ",a[i]);
    }
    return 0;
}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论