場(chǎng)景:求2021分解為五個(gè)正整數(shù)和的方法有多少種。
考慮數(shù)學(xué)方法
* 可以把2021看成2021個(gè)1的數(shù)列,采用1中間取間隔的方法分成5段
* 如5分解為三個(gè)數(shù)和: 1 | 1 1 | 1 1? ? ? ? ?4個(gè)間隔分兩段
* 那么2021分解為五個(gè)正整數(shù)和: 2020個(gè)間隔分4段 C(4,2020) = 2020*2019*2018*2017/4*3*2
而在Java中計(jì)算這個(gè)答案,出錯(cuò)。
long sum = (2020*2019*2018*2017)/(4*3*2);//出錯(cuò)
甚至一開(kāi)始都不知道錯(cuò)了,算出的答案如下:
8582718
自己用電腦自帶的計(jì)算器算后發(fā)現(xiàn)答案是691677274345。
查詢后發(fā)現(xiàn)在1024*1024*1024*2-1是2的31次方-1,正好是int的表示范圍,我的分子早就超過(guò)這個(gè)范圍,右邊表達(dá)式默認(rèn)按照int來(lái),先Int計(jì)算,再轉(zhuǎn)換為long。
所以只要將乘數(shù)表示為long,即在后面加上L標(biāo)志,就不會(huì)溢出。
long sum = (2020*2019*2018L*2017)/(4*3*2);
System.out.println(sum);//691677274345
注意L要加在快溢出的數(shù)后面,因?yàn)槲乙婚_(kāi)始加到了分子表達(dá)式的2017后面,和沒(méi)加一樣。。。
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購(gòu),新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
名稱欄目:【Java】long乘法溢出-創(chuàng)新互聯(lián)
文章位置:http://chinadenli.net/article12/dhpdgc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、網(wǎng)站策劃、虛擬主機(jī)、微信公眾號(hào)、網(wǎng)站導(dǎo)航、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容