前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【剑指Offer】56.2 数组中只出现一次的数字,其他出现3次

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

作者头像
瑞新
发布2020-12-07 10:12:00
3520
发布2020-12-07 10:12:00
举报
文章被收录于专栏:用户3288143的专栏

力扣

题目

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

示例 1:

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

思路

int位存储

代码语言:javascript
复制
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
复制
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位存储
      • 编译 自动机状态转移
      相关产品与服务
      对象存储
      对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档