给定一个包含红色、白色和蓝色、共n个元素的数组nums,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排序。
使用整数0、1和2分布表示红色、白色和蓝色。
必须在不使用库内置sort函数的情况下解决这个问题。
示例1:
cs输入:nums = [2,0,2,1,1,0] 输出:[0,0,1,1,2,2]示例2:
cs输入:nums = [2,0,1] 输出:[0,1,2]提示:
n == nums.length1 <= n <= 300nums[i]为0、1或2- 进阶:你能想出一个仅使用常数空间的一趟扫描算法吗?
本题是经典的【荷兰国旗问题】,由计算机科学家 Edsger W. Dijkstra 首先提出。
解题思路:方法一:单指针
**两次遍历:**在第一次遍历中,将数组中所有的0交换到数组头部。
第二次遍历中,将数组中所有的1交换到头部的0之后。
csvoid swap(int *a,int *b) { int t = *a; *a = *b,*b = t; } void sortColors(int *nums,int numsSize) { int ptr = 0; for(int i=0;i<numsSize;++i) { if(nums[i]==0) { swap(&nums[i],&nums[ptr]); ++ptr; } } for(int i=ptr;i<numsSize;i++) { if(nums[i]==1) { swap(&nums[i],&nums[ptr]); ++ptr; } } }时间复杂度:O(n),其中n是数组nums的长度。
空间复杂度:O(1)
方法二:双指针
使用两个指针分别来交换0和1
csvoid swap(int *a,int *b) { int t= *a; *a= *b,*b=t; } void sortColors(int *nums,int numsSize) { int p0 = 0,p1=0; for(int i=0;i<numsSize;i++) { if(nums[i]==1) { swap(&nums[i],&nums[p1]); p1++; }else if(nums[i]==0) { swap(&nums[i],&nums[p0]); if(p0<p1) swap(&nums[i],&nums[p1]); ++p0,++p1; } } }时间复杂度:O(n),其中n是数组nums的长度
空间复杂度:O(1)
方法三:双指针
左指针P0来交换0
右指针P2来交换2
csvoid swap(int *a,int *b) { int t=*a; *a=*b,*b=t; } void sortColors(int *nums,int numsSize) { int p0=0,p2=numsSize-1; for(int i=0;i<p2;i++) { while(i<=p2 && nums[i]==2) { swap(&nums[i],&nums[p2]); --p2; } if(nums[i]==0) { swap(&nums[i],&nums[p0]); ++p0; } } }时间复杂度:O(n),其中n是数组nums的长度
空间复杂度:O(1)
方法四:记录0 1 2的个数,对其进行赋值即可。
LeetCode 第75题:颜色分类
IC 见路不走2025-06-16 8:21
相关推荐
颜酱3 分钟前
从二叉树到衍生结构:5种高频树结构原理+解析不知名XL22 分钟前
day50 单调栈@––––––37 分钟前
力扣hot100—系列2-多维动态规划xsyaaaan1 小时前
代码随想录Day31动态规划:1049最后一块石头的重量II_494目标和_474一和零Jay Kay1 小时前
GVPO:Group Variance Policy OptimizationEpiphany.5562 小时前
蓝桥杯备赛题目-----爆破YuTaoShao2 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化茉莉玫瑰花茶2 小时前
C++ 17 详细特性解析(5)cpp_25012 小时前
P10570 [JRKSJ R8] 网球cpp_25012 小时前
P8377 [PFOI Round1] 暴龙的火锅