博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode-868-Binary Gap
阅读量:6636 次
发布时间:2019-06-25

本文共 1689 字,大约阅读时间需要 5 分钟。

题目描述:

Given a positive integer N, find and return the longest distance between two consecutive 1's in the binary representation of N.

If there aren't two consecutive 1's, return 0.

 

Example 1:

Input: 22Output: 2Explanation: 22 in binary is 0b10110.In the binary representation of 22, there are three ones, and two consecutive pairs of 1's.The first consecutive pair of 1's have distance 2.The second consecutive pair of 1's have distance 1.The answer is the largest of these two distances, which is 2.

Example 2:

Input: 5Output: 2Explanation: 5 in binary is 0b101.

Example 3:

Input: 6Output: 1Explanation: 6 in binary is 0b110.

Example 4:

Input: 8Output: 0Explanation: 8 in binary is 0b1000.There aren't any consecutive pairs of 1's in the binary representation of 8, so we return 0.

 

Note:

  • 1 <= N <= 10^9

 

要完成的函数:

int binaryGap(int N) 

 

说明:

1、这道题给定一个整数N,要求在N的二进制表示中找到两个连续的1(中间可以包含0),比如22的二进制表示10110中,第一位的1和第三位的1是两个连续的1,第三位的1和第四位的1是两个连续的1。

要求找到两个连续的1的最长距离,返回该距离。

2、这道题很容易,由于整数N在计算机中就是以二进制存储的,所以我们进行位操作,读取出1的位置进行计算。

代码如下:(附详解)

int binaryGap(int N)     {        int i,j,count=0,res=0;        while(N)//读取出第一个1的位置(从后面读起),存储在i中        {            count++;//count表示当前处理的是哪一位            if(N&1==1)            {                i=count;                N>>=1;                break;            }            N>>=1;//N不断右移        }        while(N)//读取所有1的位置        {            count++;            if(N&1==1)            {                j=count;//把新的1的位置记录在j中                res=max(res,j-i);//更新res值,存储最长的距离                i=j;//更新i值到当前位置            }            N>>=1;//N不断右移        }        return res;    }

上述代码实测4ms,beats 99.64% of cpp submissions。

转载于:https://www.cnblogs.com/chenjx85/p/9332944.html

你可能感兴趣的文章
idea及其插件sbt,Scala安装配置
查看>>
设计模式--这段很重要
查看>>
java读取指定package下的所有class
查看>>
settimeout 推荐的最小值
查看>>
MySQL 常用命令
查看>>
HttpClient4上传文件
查看>>
centos6.4和Ubuntu14.04搭建SNMP服务
查看>>
为微信小程序增加mixin扩展
查看>>
敏感信息识别方法探究
查看>>
创建一个可执行的python脚本
查看>>
听云APP 图表分析
查看>>
Oracle排名函数运用实例
查看>>
【推荐】[网址]PHP各种开源网站系统、cms系统一览[持续更新]
查看>>
整合 Apache 与 Tomcat
查看>>
螺旋矩阵打印java实现
查看>>
Angular 错误提示三
查看>>
easyui设置复选框 不可以选择 全选 也不能选择设置不可以选择的
查看>>
centos下java调用命令报 java.io.IOException: error=2, No such file or directory的错误
查看>>
Centos7 修改主机名
查看>>
javascript选择后弹出框消失
查看>>