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)

相关推荐
想吃火锅10051 天前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
凌波粒1 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
退休倒计时1 天前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript
小欣加油1 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒1 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
凌波粒1 天前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
吃着火锅x唱着歌1 天前
LeetCode 2530.执行K次操作后的最大分数
数据结构·算法·leetcode
sheeta19981 天前
LeetCode 每日一题笔记 日期:2026.06.16 题目:3612. 字符串特殊符号处理
笔记·算法·leetcode
CoderYanger1 天前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展
青山木1 天前
Hot 100 --- 矩阵置零
线性代数·算法·leetcode·矩阵·哈希算法