【leetcode】 兩數(shù)相除

【leetcode】 兩數(shù)相除

題目:

給定兩個整數(shù)领铐,被除數(shù) dividend 和除數(shù) divisor悯森。將兩數(shù)相除,要求不使用乘法绪撵、除法和 mod 運算符瓢姻。

返回被除數(shù) dividend 除以除數(shù) divisor 得到的商。

整數(shù)除法的結(jié)果應(yīng)當截去(truncate)其小數(shù)部分音诈,例如:truncate(8.345) = 8 以及 truncate(-2.7335) = -2

示例 1:

輸入: dividend = 10, divisor = 3
輸出: 3
解釋: 10/3 = truncate(3.33333..) = truncate(3) = 3
示例 2:

輸入: dividend = 7, divisor = -3
輸出: -2
解釋: 7/-3 = truncate(-2.33333..) = -2

提示:

被除數(shù)和除數(shù)均為 32 位有符號整數(shù)幻碱。
除數(shù)不為 0。
假設(shè)我們的環(huán)境只能存儲 32 位有符號整數(shù)细溅,其數(shù)值范圍是 [?231, 231 ? 1]褥傍。本題中,如果除法結(jié)果溢出喇聊,則返回 231 ? 1摔桦。

思路:

將除法改為多次減運算,每一次減的數(shù)遞增

java代碼

···
class Solution {
public int divide(int dividend, int divisor) {
if (dividend == 0) {
return 0;
}

    long tempDividend = (long) dividend;
    long tempDivisor = (long) divisor;

    boolean flag = true;
    if ((dividend < 0 && divisor > 0) || (dividend > 0 && divisor < 0)) {
        flag = false;
    }

    if (tempDividend < 0) {
        tempDividend = -tempDividend;
    }
    if (tempDivisor < 0) {
        tempDivisor = -tempDivisor;
    }

    long result = 0;
    while (tempDividend >= tempDivisor) {
        long k = 1;
        long temp = tempDivisor;
        while(tempDividend >= temp) {
            tempDividend -= temp;
            result += k;
            k += k;
            temp += temp;
        }
    }

    if(flag) {
        if(result > Integer.MAX_VALUE) {
            return Integer.MAX_VALUE;
        }else {
            return (int)result;
        }
    }else {
        if (-result < Integer.MIN_VALUE) {
            return Integer.MAX_VALUE;
        } else {
            return (int) (-result);
        }
    }
}

}
···

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末承疲,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子鸥咖,更是在濱河造成了極大的恐慌燕鸽,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件啼辣,死亡現(xiàn)場離奇詭異啊研,居然都是意外死亡,警方通過查閱死者的電腦和手機鸥拧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門党远,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人富弦,你說我怎么就攤上這事沟娱。” “怎么了腕柜?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵济似,是天一觀的道長。 經(jīng)常有香客問我盏缤,道長砰蠢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任唉铜,我火速辦了婚禮台舱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘潭流。我一直安慰自己竞惋,他們只是感情好柜去,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著碰声,像睡著了一般诡蜓。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胰挑,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天蔓罚,我揣著相機與錄音,去河邊找鬼瞻颂。 笑死豺谈,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的贡这。 我是一名探鬼主播茬末,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼盖矫!你這毒婦竟也來了丽惭?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤辈双,失蹤者是張志新(化名)和其女友劉穎责掏,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體湃望,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡换衬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了证芭。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瞳浦。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖废士,靈堂內(nèi)的尸體忽然破棺而出叫潦,到底是詐尸還是另有隱情,我是刑警寧澤湃密,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布诅挑,位于F島的核電站,受9級特大地震影響泛源,放射性物質(zhì)發(fā)生泄漏拔妥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一达箍、第九天 我趴在偏房一處隱蔽的房頂上張望没龙。 院中可真熱鬧,春花似錦、人聲如沸硬纤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽筝家。三九已至憎瘸,卻和暖如春勋磕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工肮帐, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留萨赁,地道東北人鞭呕。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓文捶,卻偏偏與公主長得像,于是被迫代替她去往敵國和親道伟。 傳聞我的和親對象是個殘疾皇子迹缀,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345