剑指 Offer 56 - II. 数组中数字出现的次数 II
剑指 Offer 56 - II. 数组中数字出现的次数 II
题目
链接
https://leetcode-cn.com/problems/shu-zu-zhong-shu-zi-chu-xian-de-ci-shu-ii-lcof/
问题描述
在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。
示例
输入:nums = [3,4,3,3]
输出:4
提示
1 <= nums.length <= 10000
1 <= nums[i] < 2^31
思路
首先全部转为二进制,加起来。
每一位如果可以被3整除,那就代表这位和目标数无关,用%。
然后得到的新的二进制数,就是要求的目标数。
复杂度分析
时间复杂度 O(n)
空间复杂度 O(c)
代码
Java
public int singleNumber(int[] nums) {
int[] k = new int[32];
for (int num : nums) {
for (int i = 0; i < 32; i++) {
k[i] += num & 1;
num >>= 1;
}
}
int res = 0;
for (int i = 0; i < 32; i++) {
res |= (k[i] % 3) << i;
}
return res;
}
分类:
剑指offer
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
2020-03-20 LeetCode 面试题40. 最小的k个数