做一道codewars上面初級的一道算法題看到的別人的答案。(js寫的)
二進制轉十進制,我能看得懂,也能推出來。
就是不知道其中的數(shù)學原理是什么?
還是我想多了,沒什么道理,純屬智商問題?......
const binaryArrayToNumber = arr => {
return arr.reduce((a,b)=>(a<<1|b),0);
};
@浮囡 說的很對, 就是題主不懂得的地方。
[1, 0, 1, 1, 0, 0, 0]
全程二進制看:
......
a = 1011000(2) = 88(10)
隨便選中一個整數(shù)(Math.floor(100000 * Math.random())
),假設是 42910
,轉換成二進制((42910).toString(2)
),得到字符串 "1010011110011110"
。這個字符串其實也就表示了十進制數(shù) 42910
的二進制位序
把這個字符串變成數(shù)組((42910).toString(2).split("").map(s => parseInt(s))
),得到 [1, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0]
。
現(xiàn)在暫停一下,我們想想,如果是 [4, 2, 9, 1, 0]
要生成對應的十進制整數(shù)應該怎么做?是不是:
[4, 2, 9, 1, 0]
.reduce((num, n) => num * 10 + n, 0);
如果分解 reduce 過程就是
0 * 10 + 4 = 4
4 * 10 + 2 = 42
42 * 10 + 9 = 429
429 * 10 + 1 = 4291
4291 * 10 + 0 = 42910
好了,回過頭來,我們要處理的是一個二進制數(shù)據(jù),它是按 2 進位計算,也就是說,每次循環(huán)不再是 * 10
,而是 * 2
,所以
[1, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0]
.reduce((num, n) => num * 2 + n, 0);
這也能得到答案 42910
再進一步,用乘法比較慢,但用移位就比較快了。移位是二進制操作,左移一位就相當于 * 2
(就好像對于 10 進制數(shù),左移一位右邊補 0 就是 * 10
一樣)。所以上面的 * 2
可以改成 << 1
;而 + n
這里,由于 n 取值只可能是 1 或者 0,在二進制數(shù)末位是 0 (左移位后肯定是 0)的情況下, + n
和 | n
是等效的。于是得到了題主的運算式。
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術與教育服務機構,發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。