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

【Hot100】LeetCode—75. 颜色分类

目录

  • 1- 思路
    • 题目识别
    • 技巧
  • 2- 实现
    • 75. 颜色分类——题解思路
  • 3- ACM 实现


  • 原题链接:75. 颜色分类

1- 思路

题目识别

  • 识别1 :给定三种类型数据,使得三种数据用一次遍历实现三种数据排序。

技巧

  • 用两条线将数组分为三部分
  • A 线左侧,保证数据都为 0 ;B 线右侧保证元素都是 2。


2- 实现

75. 颜色分类——题解思路

在这里插入图片描述

class Solution {
    public void sortColors(int[] nums) {
        int left = 0;
        int right = nums.length-1;
        for(int i = 0 ; i <= right;i++){
            if(nums[i] == 0){
                swap(nums,i,left++);
            }else if(nums[i] == 2){
                swap(nums,i--,right--);
            }
        }
    }

    private void swap(int[] nums,int i,int j){
        int tmp = nums[i];
        nums[i] = nums[j];
        nums[j] = tmp;
    }
}

3- ACM 实现

public class sortColors {

    public static void sortC(int[] nums){
        int left = 0;
        int right = nums.length-1;
        for(int i = 0 ; i <= right;i++){
            if(nums[i] == 0){
                swap(nums,i,left++);
            }else if(nums[i] == 2){
                swap(nums,i--,right--);
            }
        }
    }
    private static void swap(int[] nums,int i ,int j){
        int tmp = nums[i];
        nums[i] = nums[j];
        nums[j] = tmp;
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String input = sc.nextLine();
        input = input.replace("[","").replace("]","");
        String[] parts = input.split(",");
        int[] nums = new int[parts.length];
        for(int i= 0 ; i < nums.length;i++){
            nums[i] = Integer.parseInt(parts[i]);
        }
        sortC(nums);
        System.out.println("结果是");
        for(int i : nums){
            System.out.print(i+" ");
        }
    }
}


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

相关文章:

  • 嵌入式中QT实现文本与线程控制方法
  • 人工智能的发展领域之GPU加速计算的应用概述、架构介绍与教学过程
  • 121 买入股票的最佳时机
  • RAFT:随机退火森林
  • 毕业项目推荐:基于yolov8/yolov5的行人检测识别系统(python+卷积神经网络)
  • http源码分析
  • 算法基础-扩展欧几里得算法
  • Python知识点:如何使用Python进行Excel文件操作(OpenPyXL、Pandas)
  • 源码到class字节码的编译流程 字节码到内存的Java类加载流程
  • 【一分钟学C++】std::memory_order
  • Vue3+Django5+REST Framework开发电脑管理系统
  • 【计算机网络 - 基础问题】每日 3 题(一)
  • 程序的结构和控制流与数据流
  • MySQL 表的增删改查
  • 注解(Java程序的一种特殊“注释”,用于工具处理的标注)
  • 每日一问:C++ 中重写和重载的区别
  • vue3 5个常用的API
  • SpringBoot开发——整合Spring Data MongoDB
  • [数据集][目标检测]车油口挡板开关闭合检测数据集VOC+YOLO格式138张2类别
  • 凸优化学习(2)——梯度类方法求解(gradient descent)
  • 构建有温度的用户关系:开源 AI 智能名片、链动 2+1 模式与 S2B2C 商城小程序的作用
  • 华为SMU02B1管理模块WEB登录与账户密码信息
  • HTB-Archetype(winPEAS枚举工具,mssql xp_cmdshell)
  • Linux - make/Makefile工具的基础使用
  • Java的发展史与前景
  • 贪吃蛇项目实现(C语言)——附源码