首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【剑指Offer】56.2 数组中只出现一次的数字,其他出现3次

【剑指Offer】56.2 数组中只出现一次的数字,其他出现3次

作者头像
瑞新
发布2020-12-07 10:12:00
发布2020-12-07 10:12:00
44800
代码可运行
举报
运行总次数:0
代码可运行

力扣

题目

在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。

示例 1:

输入:nums = [3,4,3,3] 输出:4

思路

int位存储

代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
    public int singleNumber(int[] nums) {
        // 存储int 4*8=32每一位
        int[] arr = new int[32];
        for(int x : nums) 
            for(int i = 0; i < 32; i++) {
                arr[i] += x & 1;
                x >>= 1;// 从低到高
            }
        int res = 0, mod = 3;

        for(int i = 0; i < 32; i++) {
            res <<= 1;// 从高到低
            res += arr[31-i] % mod;
        }
        return res;
    }
}

编译 自动机状态转移

代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
    public int singleNumber(int[] nums) {
        int one = 0, two = 0;
        // {one, two}每三个状态一次转移
        // {0, 0} {1, 0} {0, 1} {0, 0}
        for(int x : nums){
            one = (one ^ x) & ~two;
            two = (two ^ x) & ~one;
        }
        return one;
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/08/30 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 思路
    • int位存储
    • 编译 自动机状态转移
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档