码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • leetcode 22.8.5 只出现一次的数字


    只出现一次的数字

    只出现一次的数字 - 只出现一次的数字 - 力扣(LeetCode)

    在这里插入图片描述

    HashMap

    看到这题,首先想到的是可不可以设计一个特殊的三进制异或规则,但转头一想或许hashmap实现起来更简单。

    public static int singleNumber(int[] nums) {
        //创建一个hashmap
        Map<Integer,Integer> map = new HashMap<>();
        for (int num : nums) {
            //这里用getOrDefault方法,取的时候可以给没有的键值对给个默认值
            map.put(num, map.getOrDefault(num, 0) + 1);
        }
        //遍历键值对,如果出现次数为1,也就是value为1,则返回
        for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
            if (entry.getValue()==1) return entry.getKey();
        }
        //为了编译通过,默认返回个0;
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    因为hashmap的查询时间复杂度为O(1)嘛,这样就可以让整个算法时间复杂度做到O(N),但空间复杂度还是O(N)

    按位运算

    因为整数每个位上不是1就是0,如果把nums中所有数的某一位全部加起来,除以3,那么剩下的就是只出现一次的数的那个位上的数。只需要做32次就可以了

    public static int singleNumber02(int[] nums){
        //先定义一个ans,作为初始化的答案
        int ans = 0;
        //因为整数是用32位二进制数储存的,我们按照位进行运算,那么就是循环32次
        for (int i = 0; i < 32; ++i) {
            int total = 0;
            for (int num: nums) {
                total += ((num >> i) & 1);
            }
            if (total % 3 != 0) {
                ans |= (1 << i);
            }
        }
        return ans;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    这个的时间复杂度为0(N),空间复杂度为O(1)

  • 相关阅读:
    【Debug】NI VISA VI_ERROR_NLISTENERS
    202206-3 CCF 角色授权 (运用stl容器模拟 + 优化 满分题解)
    计算机毕业设计Java校园统一网络授课平台系统(源码+系统+mysql数据库+Lw文档)
    Unity实现设计模式——备忘录模式
    Kyligence李栋:从数据湖到指标中台,提升数据分析ROI
    Android 12.0 Launcher3定制化功能之抽屉式(双层)app列表排序功能实现
    TXT文本文件存储
    关于webpack面试题
    pycharm 2023.2.3设置conda虚拟环境
    第二十九章 管理许可(二)
  • 原文地址:https://blog.csdn.net/weixin_54597170/article/details/126186408
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号