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

Leetcode面试经典150题-260.只出现一次的数字III

  解法都在代码里,不懂就留言或者私信

这个题算是只出现一次的数字系列比较难的题,建议先看看我写的这个系列的1、2题

Leetcode面试经典150题-136.只出现一次的数字-CSDN博客

Leetcode面试经典150题-137.只出现一次的数字II-CSDN博客

class Solution {/**本题属于只出现一次的数字系列题比较难的一个,因为涉及两个数字我们知道其他的数都出现两次,所以其他的数异或之后是0,又因为0和任何数异或的结果都是这个数所以所有数异或的结果就是我们要求的两个数的异或的结果,我们假设两个数是a,b那所有数异或的结果是a^b=x, x会等于0吗? 假设等于0,说明a、b相等了,违反了题意所以x不会为0,那x必然某一位是1,我们取最低的为1的位,这个死记硬背就行,x & (-x)然后a、b这一位必然不同,不然这一位就不是1,那就是1个0,1个1我们按照这一位是0还是1把整个数组划分为两个子数组,分别求子数组的异或得到的就是这两个数*/public int[] singleNumber(int[] nums) {/**就两个数,又肯定存在两个不一样的数,那直接返回就是答案 */if(nums.length == 2) {return nums;}/**大于两个数的情况,我们先求整体的异或 */int xorAll = 0;for(int num : nums) {xorAll ^= num;}/**去除xorAll最低位的1,结果只有这一位1,其他位都是0,这一位理论上应该判断是否越界,但是根据题目的数据范围不会越界所以我这里不判断了,如果判断的话可以写成int lowestOne = xorAll == Integer.MIN_VALUE? 1 : xorAll &(-xorAll)*/int lowestOne = xorAll &(-xorAll);/**按照最低位的1进行分流,nums1代表按这一位是0进行分组,nums2代表按这一位是1进行分组 */int num1 = 0;int num2 = 0;for(int num : nums) {if((num & lowestOne) == 0) {num1 ^= num;} else {num2 ^= num;}}return new int[]{num1, num2};}
}


http://www.mrgr.cn/news/17060.html

相关文章:

  • jQuery入门(七)jQuery实现按钮分页
  • python-数组距离
  • 2024-09-01 - 通用人工智能技术 - AI 数字人直播 - 合成篇 - 流雨声
  • OpenCPN Compiling on Windows
  • 《探讨——关于三层架构前在前端项目的应用》第一版
  • c++中的匿名对象及内存管理及模版初阶
  • Java18 设计模式
  • Linux驱动(二):模块化编程的基本操作
  • Python量化交易需要注意的股票交易佣金包含哪些
  • java构建工具-maven的复习笔记【适用于复习或者初步了解】
  • 华为OD机试真题 - 分割均衡字符串 - 贪心算法(Java/Python/JS/C/C++ 2024 D卷 100分)
  • Linux的常见指令
  • 如何使用小乌龟清除认证缓存、还原版本、定位及常用开发工具集成
  • NC 三个数的最大乘积
  • Python操作PDF文件
  • 华为云征文|部署电影收藏管理器 Radarr
  • [001-07-001].Redis中的BigKey使用分析
  • upload-labs靶场通关(附靶场环境)
  • 【C++】基础类之日期类
  • c++140namespace和ioterm