| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> (day 32 - 位运算 )剑指 Offer 56 - I. 数组中数字出现的次数 -> 正文阅读 |
|
[数据结构与算法](day 32 - 位运算 )剑指 Offer 56 - I. 数组中数字出现的次数 |
题目题链:剑指 Offer 56 - I. 数组中数字出现的次数 题解题目有规定空间复杂度必须为O(1),所以肯定不能用哈希表来记录,看了别人的题解才知道要用位运算来做,题目的思路大概如下。 大佬详细题解:剑指 Offer 56 - I. 数组中数字出现的次数(位运算,清晰图解) 只有一个数的数与其他有两个数的数一起进行异或运算最终肯定得到的是一个数的数,假如一个数组中只有一个一个数,其他都是成双成对的,这样直接用一个变量设置初始值为0,然后直接遍历数组对每个数组元素进行异或操作剩下的肯定是数组中唯一一个数。 但问题来了、题目数组中是有两个单个数的,那怎么办呢。大佬中的题解用了一个巧妙的方式进行拆分、就是先用一个为0的变量对数组每个元素进行异或、最终剩下的肯定是两个单个数的异或值、两个不同的数的异或值肯定有一位是不同的、所以我们还可以设一个变量对这个两个不同数的值进行&操作,从最低位1开始、若进行且操作等于1说明找到了不同位的数就退出,用找到的那个位的1对所有元素&进行分组,然后为0的是一组、不为0的又是一组。这样设置两个为0的变量、分别进行异或操作就得到了两个单个数了,具体看看代码。
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 | -2024/12/28 1:11:06- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |
数据统计 |