Single Number II
来源:互联网 发布:anaconda mac 安装失败 编辑:程序博客网 时间:2024/06/05 19:34
解法一:
int 数据共有32位,可以用32变量存储 这 N 个元素中各个二进制位上 1 出现的次数,最后 在进行 模三 操作,如果为1,那说明这一位是要找元素二进制表示中为 1 的那一位。代码如下:
时间:O(32*N),这是一个通用的解法,如果把出现3次改为 k 次,那么只需模k就行了。
解法二:
这是一个更快一些的解法,利用三个变量分别保存各个二进制位上 1 出现一次、两次、三次的分布情况,最后只需返回变量一就行了。代码如下:
解释:每次循环先计算 twos,即出现两次的 1 的分布,然后计算出现一次的 1 的分布,接着 二者进行与操作得到出现三次的 1 的分布情况,然后对 threes 取反,再与 ones、twos进行与操作,这样的目的是将出现了三次的位置清零。
这个方法虽然更快、更省空间了,但是并不通用。
0 0
- Single Number & Single Number II
- Single Number & Single Number II
- Single Number II - leetcode
- Leetcode: Single Number II
- Single Number II
- Single Number II
- [LeetCode] Single Number II
- LeetCode: Single Number II
- leetcode -- Single Number II
- [leetcode]Single Number II
- [LeetCode] Single Number II
- 【leetcode】Single Number II
- Single Number I & II
- LeetCode:Single Number II
- Leetcode: Single Number II
- Single Number II
- leetcode :Single Number II
- Leetcode Single Number II
- oracle 循环语句示例
- 3-4:has(selector)过滤选择器
- URAL - 1057 Amount of Degrees
- Android集成支付宝步骤讲解
- XPath学习笔记
- Single Number II
- 2016-7
- Mybatis步步进阶(五)——Mybatis输入输出映射及动态SQL Review
- 皮尔逊相关系数
- python 字符编码处理
- Java千百问_06数据结构(023)_基本数据类型在内存中如何存放
- 跟我一起学Multiple View Geometry多视图几何(3)
- 【Django开发】阿里云服务器+apache+django部署你的网站
- 3-5:hidden过滤选择器