C语言 | Leetcode C语言题解之第75题颜色分类

题目:

题解:

cpp 复制代码
void 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;
        }
    }
}
相关推荐
流年如夢12 分钟前
编译链接流程与底层细节
c语言
Navigator_Z13 分钟前
LeetCode //C - 1026. Maximum Difference Between Node and Ancestor
c语言·算法·leetcode
We་ct22 分钟前
LeetCode 63. 不同路径 II:动态规划解题详解
前端·算法·leetcode·typescript·动态规划
xin_nai35 分钟前
LeetCode热题100(Java)(3)滑动窗口
算法·leetcode·滑动窗口
YSF2017_31 小时前
C语言15-makefile(2)——makefile的自定义变量及两个函数
c语言·开发语言
踩坑记录1 小时前
leetcode hot100 5. 最长回文子串 中心扩展法 medium
leetcode
Lazionr1 小时前
数据结构入门:栈实现全解析
c语言·数据结构
踩坑记录1 小时前
leetcode hot100 1143. 最长公共子序列 mediuim 递归优化
leetcode
光子物联单片机2 小时前
STM32传感器模块编程实践(二十)ESP8266实现MQTT连接OneNET上传温湿度数据
c语言·stm32·单片机·嵌入式硬件·mqtt
无限进步_2 小时前
【C++】寻找数组中出现次数超过一半的数字:三种解法深度剖析
开发语言·c++·git·算法·leetcode·github·visual studio