JAVA语言之三色排序

2023-05-16

有一个只由0,1,2三种元素构成的整数数组,请使用交换、原地排序而不是使用计数进行排序。

给定一个只含0,1,2的整数数组A及它的大小,请返回排序后的数组。保证数组大小小于等于500。

测试样例:
[0,1,1,0,2,2],6
返回:[0,0,1,1,2,2]
可以用两个变量left和right分别代表0和2的阵营
代码如下:
    public int[] sortThreeColor(int[] A, int n) {
       int left=-1;
       int right=A.length;
       int i=0;
       while(i<right){
           
    	   if(A[i]==0){
    		//将0阵营的用left来表示出并用i++指向下一个元素;
               swap(A,i,++left);
    		   i++;
    		   
    	   }else if(A[i]==2){
               //为什么这里不用i++
               //是因为当前元素等于2时,交换最后一个元素和当前元素
               //这时只能判断最后一个是2并且是2阵营的
               //当时交换的最后一个元素不一定是2所以又要继续判断一次
    		   swap(A,i,--right);
    		   
    	   }else{
    		   i++;
    	   }
       }
       return A;
    }
    public  void swap(int[] a, int i, int j) {
	       if(i!=j){
	    	   int temp=a[i];
               a[i]=a[j];
               a[j]=temp;
	       }
}


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

JAVA语言之三色排序 的相关文章

随机推荐

  • 确定两串乱序同构之程序员面试经典

    给定两个字符串 xff0c 请编写程序 xff0c 确定其中一个字符串的字符重新排列后 xff0c 能否变成另一个字符串 这里规定大小写为不同字符 xff0c 且考虑字符串重点空格 给定一个string stringA 和一个string
  • 基本字符串压缩之程序员面试经典

    利用字符重复出现的次数 xff0c 编写一个方法 xff0c 实现基本的字符串压缩功能 比如 xff0c 字符串 aabcccccaaa 经压缩会变成 a2b1c5a3 若压缩后的字符串没有变短 xff0c 则返回原先的字符串 给定一个st
  • 像素翻转之程序员面试经典

    有一副由NxN矩阵表示的图像 xff0c 这里每个像素用一个int表示 xff0c 请编写一个算法 xff0c 在不占用额外内存空间的情况下 即不使用缓存矩阵 xff0c 将图像顺时针旋转90度 给定一个NxN的矩阵 xff0c 和矩阵的阶
  • 清除行列之程序员面试经典

    请编写一个算法 xff0c 若MxN矩阵中某个元素为0 xff0c 则将其所在的行与列清零 给定一个MxN的int 矩阵 C 43 43 中为vector lt vector gt mat 和矩阵的阶数n xff0c 请返回完成操作后的in
  • JAVA语言之归并排序

    package com paixu public class guibing public static void main String args int A 61 new int 5 3 4 2 1 A 61 guibing merge
  • 程序员面试经典之链表分割

    题目描述 编写代码 xff0c 以给定值x为基准将链表分割成两部分 xff0c 所有小于x的结点排在大于或等于x的结点之前 给定一个链表的头指针 ListNode pHead xff0c 请返回重新排列后的链表的头指针 注意 xff1a 分
  • JAVA语言之计数排序

    非比较的计数排序可以用桶排序的方式实现 代码如下 xff1a package com paixu public class jishu public static void main String args int A 61 new int
  • JAVA语言之基数排序

    基数排序简而言之可以创建0 9余数共十个桶 代码如下 xff1a public class jishu 1 public static void main String args int A 61 new int 54 35 48 36 2
  • 链式A+B之程序员面试经典

    有两个用链表表示的整数 xff0c 每个结点包含一个数位 这些数位是反向存放的 xff0c 也就是个位排在链表的首部 编写函数对这两个整数求和 xff0c 并用链表形式返回结果 给定两个链表ListNode A xff0c ListNode
  • Android逆向【4】:暴力破解APK签名校验,愉快的重新打包微信支付宝APK

    回顾 Android逆向小技巧 xff1a 批量注入日志 xff0c 打印目标程序执行流程 在上一篇2019年的文章中 xff0c 我们使用python写了一个简单的文本处理工具 xff1a https github com encoder
  • Anaconda相关shell命令相关知识点

    文章目录 前言一 Anaconda或Miniconda镜像下载二 配置Anaconda源1 查看安装过的镜像1 显示镜像源 xff0c 如果是新安装Anaconda则默认使用国外镜像源 xff0c 它会显示2 若有新的镜像源 xff0c 它
  • 回文链表之程序员面试经典

    题目描述 请编写一个函数 xff0c 检查链表是否为回文 给定一个链表ListNode pHead xff0c 请返回一个bool xff0c 代表链表是否为回文 测试样例 xff1a 1 2 3 2 1 返回 xff1a true 1 2
  • 集合栈之程序员面试经典

    题目描述 请实现一种数据结构SetOfStacks xff0c 由多个栈组成 xff0c 其中每个栈的大小为size xff0c 当前一个栈填满时 xff0c 新建一个栈 该数据结构应支持与普通栈相同的push和pop操作 给定一个操作序列
  • JAVA语言之全排列的递归实现

    问题 xff1a 假如有一个数组的值为1 2 2 3 4 5一共六个值 xff0c 进行全排列 xff0c 但要求是3和5不能在一起 xff0c 并且4不能在第三个位置 代码如下 public class testtest public s
  • 猫狗收容所之程序员面试经典

    题目描述 有家动物收容所只收留猫和狗 xff0c 但有特殊的收养规则 xff0c 收养人有两种收养方式 xff0c 第一种为直接收养所有动物中最早进入收容所的 xff0c 第二种为选择收养的动物类型 xff08 猫或狗 xff09 xff0
  • 双栈排序之程序员面试经典

    题目描述 请编写一个程序 xff0c 按升序对栈进行排序 xff08 即最大元素位于栈顶 xff09 xff0c 要求最多只能使用一个额外的栈存放临时数据 xff0c 但不得将元素复制到别的数据结构中 给定一个int numbers C 4
  • 用两个栈实现队列之程序员面试经典

    题目描述 用两个栈来实现一个队列 xff0c 完成队列的Push和Pop操作 队列中的元素为int类型 比如有栈A和栈B xff0c 在模拟队列的时候先将所有数据依次放入栈A中 xff0c 在要弹出的时候将A中的数据依次从上到下放进栈B x
  • 高度最小的BST之程序员面试经典

    题目描述 对于一个元素各不相同且按升序排列的有序序列 xff0c 请编写一个算法 xff0c 创建一棵高度最小的二叉查找树 给定一个有序序列int vals 请返回创建的二叉查找树的高度 二叉排序树 xff08 Binary Sort Tr
  • 二叉树平衡检查之程序员面试经典

    题目描述 实现一个函数 xff0c 检查二叉树是否平衡 xff0c 平衡的定义如下 xff0c 对于树中的任意一个结点 xff0c 其两颗子树的高度差不超过1 给定指向树根结点的指针TreeNode root xff0c 请返回一个bool
  • JAVA语言之三色排序

    有一个只由0 xff0c 1 xff0c 2三种元素构成的整数数组 xff0c 请使用交换 原地排序而不是使用计数进行排序 给定一个只含0 xff0c 1 xff0c 2的整数数组A 及它的大小 xff0c 请返回排序后的数组 保证数组大小