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;
        }
    }
}
相关推荐
yuuki2332332 小时前
【数据结构】用顺序表实现通讯录
c语言·数据结构·后端
夏鹏今天学习了吗2 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
还是码字踏实2 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
ad钙奶长高高3 小时前
【C语言】扫雷游戏详解
c语言
轮到我狗叫了5 小时前
力扣.84柱状图中最大矩形 力扣.134加油站牛客.abb(hard 动态规划+哈希表)牛客.哈夫曼编码
算法·leetcode·职场和发展
丛雨要玩游戏5 小时前
字符函数和字符串函数
c语言·开发语言·算法
ad钙奶长高高6 小时前
【C语言】初始C语言
c语言·开发语言·算法
侯小啾6 小时前
【17】C语言-gets() 与 fgets() 函数
c语言·开发语言
是苏浙7 小时前
零基础入门C语言之枚举和联合体
c语言·开发语言
熬了夜的程序员7 小时前
【LeetCode】99. 恢复二叉搜索树
算法·leetcode·职场和发展