当前位置: 首页 > article >正文

力扣刷题--2595. 奇偶位数【简单】

题目描述

给你一个 正 整数 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的个数,注意本体的奇数偶数下标是从右往左的

完整代码

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;
    }
};

http://www.kler.cn/news/332004.html

相关文章:

  • 端侧Agent系列 | 端侧AI Agent任务拆解大师如何助力AI手机?(详解版)
  • SpringCloud入门(十二)全局过滤器和跨域
  • launcher.py: error: the following arguments are required: --output_dir
  • RabbitMQ 实验入门
  • opencv-如何获取图像区域特定像素区域大小
  • 配置Nginx以支持通过HTTPS回源到CDN
  • Solidity 存储和内存管理:深入理解与高效优化
  • ESP01 AT指令学习
  • AndroidStudio编译问题
  • Yolov8改进轻量级网络Ghostnetv2
  • 828华为云征文|华为云Flexus云服务器X实例——uniapp功能开发、搭建股票系统选择用什么服务器比较好?
  • 在掌控板中加载人教版信息科技教学指南中的educore库
  • C++系列-STL容器中的排序算法
  • 【云原生安全篇】Cosign助力Harbor验证镜像实践
  • 网站开发基础:JavaScript
  • AWS Redshift 如何让新的table创建即自动赋予权限
  • SQL高级语法
  • SSH(安全外壳协议)可以基于多种加密算法
  • Elasticsearch 8.16 和 JDK 23 中的语言环境变化
  • php与python建站的区别有哪些