C++實(shí)現(xiàn)LeetCode(29.兩數(shù)相除)
[LeetCode] 29. Divide Two Integers 兩數(shù)相除
Given two integers dividend and divisor, divide two integers without using multiplication, division and mod operator.
Return the quotient after dividing dividend by divisor.
The integer division should truncate toward zero.
Example 1:
Input: dividend = 10, divisor = 3
Output: 3
Example 2:
Input: dividend = 7, divisor = -3
Output: -2
Note:
- Both dividend and divisor will be 32-bit signed integers.
- The divisor will never be 0.
- Assume we are dealing with an environment which could only store integers within the 32-bit signed integer range: [−231, 231 − 1]. For the purpose of this problem, assume that your function returns 231 − 1 when the division result overflows.
這道題讓我們求兩數(shù)相除,而且規(guī)定不能用乘法,除法和取余操作,那么這里可以用另一神器位操作 Bit Manipulation,思路是,如果被除數(shù)大于或等于除數(shù),則進(jìn)行如下循環(huán),定義變量t等于除數(shù),定義計(jì)數(shù)p,當(dāng)t的兩倍小于等于被除數(shù)時(shí),進(jìn)行如下循環(huán),t擴(kuò)大一倍,p擴(kuò)大一倍,然后更新 res 和m。這道題的 OJ 給的一些 test case 非常的討厭,因?yàn)檩斎氲亩际?int 型,比如被除數(shù)是 -2147483648,在 int 范圍內(nèi),當(dāng)除數(shù)是 -1 時(shí),結(jié)果就超出了 int 范圍,需要返回 INT_MAX,所以對(duì)于這種情況就在開始用 if 判定,將其和除數(shù)為0的情況放一起判定,返回 INT_MAX。然后還要根據(jù)被除數(shù)和除數(shù)的正負(fù)來確定返回值的正負(fù),這里采用長(zhǎng)整型 long 來完成所有的計(jì)算,最后返回值乘以符號(hào)即可,代碼如下:
解法一:
class Solution {
public:
int divide(int dividend, int divisor) {
if (dividend == INT_MIN && divisor == -1) return INT_MAX;
long m = labs(dividend), n = labs(divisor), res = 0;
int sign = ((dividend < 0) ^ (divisor < 0)) ? -1 : 1;
if (n == 1) return sign == 1 ? m : -m;
while (m >= n) {
long t = n, p = 1;
while (m >= (t << 1)) {
t <<= 1;
p <<= 1;
}
res += p;
m -= t;
}
return sign == 1 ? res : -res;
}
};
我們可以通過遞歸的方法來解使上面的解法變得更加簡(jiǎn)潔:
解法二:
class Solution {
public:
int divide(int dividend, int divisor) {
long m = labs(dividend), n = labs(divisor), res = 0;
if (m < n) return 0;
long t = n, p = 1;
while (m > (t << 1)) {
t <<= 1;
p <<= 1;
}
res += p + divide(m - t, n);
if ((dividend < 0) ^ (divisor < 0)) res = -res;
return res > INT_MAX ? INT_MAX : res;
}
};
到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(29.兩數(shù)相除)的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)兩數(shù)相除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú))
- C++實(shí)現(xiàn)LeetCode(33.在旋轉(zhuǎn)有序數(shù)組中搜索)
- C++實(shí)現(xiàn)LeetCode(32.最長(zhǎng)有效括號(hào))
- C++實(shí)現(xiàn)LeetCode(31.下一個(gè)排列)
- C++實(shí)現(xiàn)LeetCode(30.串聯(lián)所有單詞的子串)
- C++實(shí)現(xiàn)LeetCode(28.實(shí)現(xiàn)strStr()函數(shù))
- C++實(shí)現(xiàn)LeetCode(37.求解數(shù)獨(dú))
相關(guān)文章
解決codeblocks致命錯(cuò)誤:openssl/aes.h:沒有這樣的文件或目錄問題
這篇文章主要介紹了解決codeblocks致命錯(cuò)誤:openssl/aes.h:沒有這樣的文件或目錄問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
C語(yǔ)言+EasyX實(shí)現(xiàn)數(shù)字雨效果
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言+EasyX實(shí)現(xiàn)數(shù)字雨效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11
基于QT設(shè)計(jì)一個(gè)春聯(lián)自動(dòng)生成器
春節(jié)是中國(guó)最隆重的傳統(tǒng)節(jié)日,一到過年家家戶戶肯定是要貼春聯(lián);在春節(jié)前夕,會(huì)用大紅紙張,加上濃墨書寫祝福詞語(yǔ)。本文將利用Qt框架設(shè)計(jì)一個(gè)春聯(lián)自動(dòng)生成器,需要的可以參考一下2022-01-01
C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的通訊錄
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
C++中std::priority_queue的使用小結(jié)
std::priority_queue是C++ STL提供的優(yōu)先隊(duì)列,本文主要介紹了C++中std::priority_queue的使用小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2025-04-04
C++調(diào)用迅雷接口解析XML下載功能(迅雷下載功能)
這篇文章主要介紹了C++調(diào)用迅雷接口,封裝解析XML下載的類,功能簡(jiǎn)單,大家參考使用吧2013-11-11
Qt實(shí)現(xiàn)部件透明陰影效果與不規(guī)則窗體詳解
這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)部件透明陰影效果與不規(guī)則窗體的相關(guān)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-01-01

