《劍指offer》— JavaScript(11)二進制中1的個數(shù)

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

題目描述

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


思路一

  1. 用1和n進行位運算,結(jié)果為1則n的二進制最右邊一位為1衔瓮,否則為0浊猾;
  2. 將n二進制形式右移1位,繼續(xù)與1進行位運算热鞍;
  3. 由于負數(shù)右移時最高位補1葫慎,因此不能采用算術(shù)右移,而使用不考慮符號位的邏輯右移薇宠。

實現(xiàn)代碼

function NumberOf1(n)
{
       var count = 0;
        while (n != 0) {
            if ((n & 1) == 1) {
                count++;
            }
            n = n >>> 1;
        }
        return count;
}

思路二

  1. 用1和n進行位運算偷办,結(jié)果為1則n的二進制最右邊一位為1,否則為0澄港;
  2. 將1左移一位繼續(xù)進行位運算椒涯,直到左移32位截至。

實現(xiàn)代碼

function NumberOf1(n) {
    if (n === 0) {
        return 0;
    }
    var count = 0,
        flag = 1;
    while (flag) {
        if (n & flag) {
            count++;
        }
        flag = flag << 1;
        console.log(flag); // 打印flag
    }
    return count;
}
圖片.png

思路三

  1. 如果一個整數(shù)不為0回梧,那么這個整數(shù)至少有一位是1废岂。如果我們把這個整數(shù)減1祖搓,那么原來處在整數(shù)最右邊的1就會變?yōu)?,原來在1后面的所有的0都會變成1(如果最右邊的1后面還有0的話)湖苞。其余所有位將不會受到影響拯欧;
  2. 例如:一個二進制數(shù)1100,從右邊數(shù)起第三位是處于最右邊的一個1财骨。減去1后镐作,第三位變成0,它后面的兩位0變成了1隆箩,而前面的1保持不變该贾,因此得到的結(jié)果是1011;
  3. 我們再把原來的整數(shù)和減去1之后的結(jié)果做與運算捌臊,從原來整數(shù)最右邊一個1那一位開始所有位都會變成0杨蛋。如1100&1011=1000;
  4. 因此理澎,把一個整數(shù)減去1六荒,再和原整數(shù)做與運算,會把該整數(shù)最右邊一個1變成0.那么一個整數(shù)的二進制有多少個1矾端,就將進行多少次這樣的操作。

實現(xiàn)代碼

function NumberOf1(n) {
    var count = 0;
    while (n != 0) {
        ++count;
        n = (n - 1) & n;
    }
    return count;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末卵皂,一起剝皮案震驚了整個濱河市秩铆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌灯变,老刑警劉巖殴玛,帶你破解...
    沈念sama閱讀 211,561評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異添祸,居然都是意外死亡滚粟,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評論 3 385
  • 文/潘曉璐 我一進店門刃泌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來凡壤,“玉大人,你說我怎么就攤上這事耙替⊙窍溃” “怎么了?”我有些...
    開封第一講書人閱讀 157,162評論 0 348
  • 文/不壞的土叔 我叫張陵俗扇,是天一觀的道長硝烂。 經(jīng)常有香客問我,道長铜幽,這世上最難降的妖魔是什么滞谢? 我笑而不...
    開封第一講書人閱讀 56,470評論 1 283
  • 正文 為了忘掉前任串稀,我火速辦了婚禮,結(jié)果婚禮上狮杨,老公的妹妹穿的比我還像新娘母截。我一直安慰自己,他們只是感情好禾酱,可當我...
    茶點故事閱讀 65,550評論 6 385
  • 文/花漫 我一把揭開白布微酬。 她就那樣靜靜地躺著,像睡著了一般颤陶。 火紅的嫁衣襯著肌膚如雪颗管。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,806評論 1 290
  • 那天滓走,我揣著相機與錄音垦江,去河邊找鬼。 笑死搅方,一個胖子當著我的面吹牛比吭,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播姨涡,決...
    沈念sama閱讀 38,951評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼衩藤,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了涛漂?” 一聲冷哼從身側(cè)響起赏表,我...
    開封第一講書人閱讀 37,712評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎匈仗,沒想到半個月后瓢剿,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,166評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡悠轩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,510評論 2 327
  • 正文 我和宋清朗相戀三年间狂,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片火架。...
    茶點故事閱讀 38,643評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡鉴象,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出何鸡,到底是詐尸還是另有隱情炼列,我是刑警寧澤,帶...
    沈念sama閱讀 34,306評論 4 330
  • 正文 年R本政府宣布音比,位于F島的核電站俭尖,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜稽犁,卻給世界環(huán)境...
    茶點故事閱讀 39,930評論 3 313
  • 文/蒙蒙 一焰望、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧已亥,春花似錦熊赖、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至捆姜,卻和暖如春传趾,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背泥技。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評論 1 266
  • 我被黑心中介騙來泰國打工浆兰, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人珊豹。 一個月前我還...
    沈念sama閱讀 46,351評論 2 360
  • 正文 我出身青樓簸呈,卻偏偏與公主長得像,于是被迫代替她去往敵國和親店茶。 傳聞我的和親對象是個殘疾皇子蜕便,可洞房花燭夜當晚...
    茶點故事閱讀 43,509評論 2 348

推薦閱讀更多精彩內(nèi)容