Leetcode JAVA刷刷站(75)颜色分类

一、题目概述

二、思路方向

在Java中,要实现这个排序算法,我们可以使用三指针的方法,也称作荷兰国旗问题(Dutch National Flag Problem)。这个方法使用三个指针来分别追踪数组中小于、等于和大于中间值的元素的边界。在这个特定的问题中,中间值是1(代表白色),但我们实际上更关心的是将0(红色)放在前面,将2(蓝色)放在后面,而1(白色)则位于中间。

三、代码实现

java 复制代码
public class Solution {  
    public void sortColors(int[] nums) {  
        if (nums == null || nums.length <= 1) {  
            return;  
        }  
  
        int low = 0; // 小于中间值的指针  
        int mid = 0; // 当前遍历的指针  
        int high = nums.length - 1; // 大于中间值的指针  
  
        while (mid <= high) {  
            if (nums[mid] == 0) {  
                // 如果当前元素是0,则与low指向的元素交换,并将两个指针都向前移动  
                swap(nums, low, mid);  
                low++;  
                mid++;  
            } else if (nums[mid] == 1) {  
                // 如果当前元素是1,则只将mid指针向前移动  
                mid++;  
            } else { // nums[mid] == 2  
                // 如果当前元素是2,则与high指向的元素交换,但只将high指针向后移动  
                swap(nums, mid, high);  
                high--;  
            }  
        }  
    }  
  
    // 交换数组中两个位置的值  
    private void swap(int[] nums, int i, int j) {  
        int temp = nums[i];  
        nums[i] = nums[j];  
        nums[j] = temp;  
    }  
  
    public static void main(String[] args) {  
        Solution solution = new Solution();  
        int[] nums = {2, 0, 2, 1, 1, 0};  
        solution.sortColors(nums);  
        for (int num : nums) {  
            System.out.print(num + " ");  
        }  
    }  
}

执行结果:

四、小结

在这个代码中,low 指针用于追踪所有小于1(即0)的元素的边界,mid 指针用于遍历数组,high 指针用于追踪所有大于1(即2)的元素的边界。当mid指针遇到0时,它与low指针交换,并将两个指针都向前移动;当mid指针遇到1时,它只向前移动;当mid指针遇到2时,它与high指针交换,但只将high指针向后移动。这个过程一直持续到mid指针超过high指针为止,此时数组就被排序好了。

结语

谁勇敢地经受过青春之火的洗礼

谁就毫不惧怕晚年的严寒冰霜

!!!

相关推荐
唐青枫3 分钟前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis
码语智行4 分钟前
MQTT 配置、依赖与使用说明
java·物联网·mt
_日拱一卒5 分钟前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
无限进步_6 分钟前
【Linux】进程状态、僵尸与孤儿、进程调度
linux·运维·服务器·开发语言·数据结构·算法
郝学胜-神的一滴6 分钟前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
仙俊红7 分钟前
反射到底解决什么问题?
java·开发语言
2301_764441338 分钟前
基于Stackelberg博弈的分散式库存模型
python·算法·数学建模
小森林之主10 分钟前
凌晨3点的闹钟:分布式定时任务设计实战
java·redis·任务调度·cron·分布式定时任务
yaoxin52112312 分钟前
430. Java 日期时间 API - 时间计算 Temporal 包
java·前端·python
qq 137401861117 分钟前
医用无菌屏障系统加速老化标准解读:ASTM F1980-2016 全解析
人工智能·算法·加速老化·包装测试·astm·医疗器械包装·无菌屏障系统