题干
给定一个包含红色、白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。
此题中,我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。
注意: 不能使用代码库中的排序函数来解决这道题。
示例:
输入
: [2,0,2,1,1,0]
输出
: [0,0,1,1,2,2]
进阶:
一个直观的解决方案是使用计数排序的两趟扫描算法。
首先,迭代计算出
0、
1 和
2 元素的个数,然后按照
0、
1、
2的排序,重写当前数组。
你能想出一个仅使用常数空间的一趟扫描算法吗?
想法
题干都还没看完就知道了,经典快排 用双指针初始指向前后数组边界 向后扫描,遇到小于1的直接和头指针交换,因为小的肯定是0,接着扫描后一个 遇到大于1的先把现在的数和后指针交换,i不++ 因为有可能交换了一个0到现在的位置
java代码
class Solution {
public void sortColors(int[] nums
) {
int i
=0;
int less
=-1;
int more
=nums
.length
;
while(i
<more
){
if(nums
[i
]<1){
swap(nums
,++less
,i
++);
}
else if (nums
[i
]>1){
swap(nums
,--more
,i
);
}
else {
i
++;
}
}
}
public void swap(int []nums
,int i
,int j
){
int t
=nums
[i
];
nums
[i
]=nums
[j
];
nums
[j
]=t
;
}
}
我的leetcode代码都已经上传到我的githttps://github.com/ragezor/leetcode