Leetcode 75 Sort colors

题意:荷兰国旗问题,给一个数组[0,0,2,1,0],构造成[0,0,0,1,2]的形式,分成三块

https://leetcode.com/problems/sort-colors/description/

题解:

在任意时刻,i 左边的数都是 0,k 右边的数都是 2,而 i 到 j 之间的数都是 1。

想象有三个指针, i , j , k i, j, k i,j,k 维护 [ 0 , i ) [0,i) [0,i)为0,维护$[i,j)为1,[j, nums.size()]为2

想象有三个指针在动,i代表起始位置,k代表末尾位置,j遍历整个数组,移动j,当j的值指向的数字为0,的时候那么跟i交换,移动的过程中j >=i

cpp 复制代码
class Solution {
public:
    void sortColors(vector<int>& nums) {
        for(int i = 0, j = 0, k = nums.size()-1; k >= j;) {
            if(!nums[j]) {
                swap(nums[i++], nums[j++]);
            } else if( nums[j] == 2) {
                swap(nums[j],nums[k--]);
            } else j++;
        }
    }
};

时间复杂度 O ( n ) O(n) O(n)

空间复杂度 O ( 1 ) O(1) O(1)

相关推荐
啊哦呃咦唔鱼1 小时前
LeetCode双指针合集
算法·leetcode·职场和发展
alphaTao1 小时前
LeetCode 每日一题 2026/4/13-2026/4/19
算法·leetcode·职场和发展
f3iiish4 小时前
3783. 整数的镜像距离 力扣
算法·leetcode
小雅痞5 小时前
[Java][Leetcode hard] 135. 分发糖果
java·算法·leetcode
嘻嘻哈哈樱桃5 小时前
数据流中的中位数 力扣--160
算法·leetcode·职场和发展
j_xxx404_5 小时前
力扣算法题:字符串(最长公共前缀|最长回文子串)
c++·算法·leetcode
人道领域5 小时前
【LeetCode刷题日记】:344,541-字符串反转字符串反转技巧:双指针原地交换法
算法·leetcode·面试
木子墨51614 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
故事和你9118 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
y = xⁿ21 小时前
20天速通LeetCode day07:前缀和
数据结构·算法·leetcode