题目描述
给你一个 正 整数 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的个数,注意本体的奇数偶数下标是从右往左的
完整代码
cpp
class Solution {
public:
vector<int> evenOddBit(int n) {
//先把n转为二进制的字符串
string res;
while(n)
{
res=to_string(n%2)+res;
n/=2;
}
//题目中的奇偶是从右往左算的
vector<int>ans;
int even=0;
int odd=0;
int len=res.size()-1;
for(int i=len;i>=0;i--)
{
if(res[i]=='1')
{
if((len-i)%2==0)
even++;
else
odd++;
}
}
ans.push_back(even);
ans.push_back(odd);
return ans;
}
};