当前位置: 首页 > article >正文

[算法] [leetcode-75] 颜色分类

75 颜色分类

给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums ,原地 对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。

我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。

必须在不使用库内置的 sort 函数的情况下解决这个问题。

示例 1:

输入:nums = [2,0,2,1,1,0]
输出:[0,0,1,1,2,2]
示例 2:

输入:nums = [2,0,1]
输出:[0,1,2]

提示:

n == nums.length
1 <= n <= 300
nums[i] 为 0、1 或 2

进阶:

你能想出一个仅使用常数空间的一趟扫描算法吗?


class Solution {

    public void swap(int [] nums, int begin, int end){
        if(begin<0 || end<0 ||begin>=nums.length ||end>=nums.length){
            return;
        }
        int tmp = nums[begin];
        nums[begin] = nums[end];
        nums[end] = tmp; 
    }
    public void sortColors(int[] nums) {
        chessSort(nums);
    }

    public void chessSort(int[] nums){
        int midNum = 1;
        int beginRange = 0-1;
        int endRange = nums.length ;
        int index = 0;
        while(index<endRange){
            if(nums[index] == midNum){
                index++;
            } else if(nums[index] < midNum){
                beginRange++;
                swap(nums, beginRange, index);
                index++;
            } else {
                endRange--;
                swap(nums, endRange, index);
                index = index;
            }
        }
    }
}

http://www.kler.cn/a/460286.html

相关文章:

  • 掌握机器学习与MySQL集成实战Ruby和JavaScript辅助Redis缓存策略
  • 双目视觉:reprojectImageTo3D函数
  • Scala Collection(集合)
  • 解锁手机矩阵的流量密码:云手机的奇幻之旅
  • 记一次音频无输出的解决方案
  • ES中查询中参数的解析
  • Paimon_01_241020
  • 前端超大缓存IndexDB、入门及实际使用
  • win10 重装系统中 或 电脑恢复重置中的 优化步骤
  • 寄存器总结
  • 开发小工具:ping地址
  • django StreamingHttpResponse fetchEventSource实现前后端流试返回数据并接收数据的完整详细过程
  • PHP框架+gatewayworker实现在线1对1聊天--mysql数据库(3)
  • Spring boot + Hibernate + MySQL实现用户管理示例
  • logback之自定义过滤器
  • 【AndroidAPP】权限被拒绝:[android.permission.READ_EXTERNAL_STORAGE],USB设备访问权限系统报错
  • C语言一维数组与指针运算
  • 《计算机组成及汇编语言原理》阅读笔记:p133-p159
  • WPF的下拉复选框多选,数据来源数据库的表
  • 【人工智能机器学习基础篇】——深入详解深度学习之神经网络基础:理解前馈神经网络与反向传播算法