劍指Offer - 11 - 二進制中1的個數(shù)

題目描述

二進制中1的個數(shù)

輸入一個整數(shù),輸出該數(shù)二進制表示中1的個數(shù)。其中負數(shù)用補碼表示。

思路

  1. 一個數(shù)n與n-1按位與后,該數(shù)最右邊的1變?yōu)?
  2. 在python中int是無精度的,所以負數(shù)補碼左邊有無限個1,需要轉換

Code

  • Python
# -*- coding:utf-8 -*-
class Solution:
  def NumberOf1(self, n):
    return bin(n).count("1") if n>=0 else bin(2**32+n).count("1")
  • JavaScript
function NumberOf1(n)
{
  let count = 0
  while(n!= 0){
    count += 1
    n = n & (n - 1)
  }
  return count
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容