2595.奇偶位数:位运算
【LetMeFly】2595.奇偶位数:位运算
力扣题目链接:https://leetcode.cn/problems/number-of-even-and-odd-bits/
给你一个 正 整数 n
。
用 even
表示在 n
的二进制形式(下标从 0 开始)中值为 1
的偶数下标的个数。
用 odd
表示在 n
的二进制形式(下标从 0 开始)中值为 1
的奇数下标的个数。
返回整数数组 answer
,其中 answer = [even, odd]
。
示例 1:
输入:n = 17 输出:[2,0] 解释:17 的二进制形式是 10001 。 下标 0 和 下标 4 对应的值为 1 。 共有 2 个偶数下标,0 个奇数下标。
示例 2:
输入:n = 2 输出:[0,1] 解释:2 的二进制形式是 10 。 下标 1 对应的值为 1 。 共有 0 个偶数下标,1 个奇数下标。
提示:
1 <= n <= 1000
挺好一道题。
解题方法:位运算
解决这道题需要解决三个问题:
如何取出$n$的最低位?
n & 1
即可如何移除$n$的最低为?
直接右移
n >>= 1
即可如何变换奇偶下标?
布尔类型
index = !index
或整型index ^= 1
都可
- 时间复杂度$O(\log(n))$。$\log 1024=10$,运算次数很低。
- 空间复杂度$O(1)$
AC代码
C++
1 |
|
Python
1 |
|
Java
1 |
|
Go
1 |
|
同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
千篇源码题解已开源
Tisfy:https://blog.letmefly.xyz/2025/02/20/LeetCode 2595.奇偶位数/
2595.奇偶位数:位运算
https://blog.letmefly.xyz/2025/02/20/LeetCode 2595.奇偶位数/