亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++中怎么利用LeetCode實現兩數相除

發布時間:2021-07-14 11:40:01 來源:億速云 閱讀:162 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關C++中怎么利用LeetCode實現兩數相除,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

[LeetCode] 29. Divide Two Integers 兩數相除

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.

這道題讓我們求兩數相除,而且規定不能用乘法,除法和取余操作,那么這里可以用另一神器位操作 Bit Manipulation,思路是,如果被除數大于或等于除數,則進行如下循環,定義變量t等于除數,定義計數p,當t的兩倍小于等于被除數時,進行如下循環,t擴大一倍,p擴大一倍,然后更新 res 和m。這道題的 OJ 給的一些 test case 非常的討厭,因為輸入的都是 int 型,比如被除數是 -2147483648,在 int 范圍內,當除數是  -1 時,結果就超出了 int 范圍,需要返回 INT_MAX,所以對于這種情況就在開始用 if 判定,將其和除數為0的情況放一起判定,返回 INT_MAX。然后還要根據被除數和除數的正負來確定返回值的正負,這里采用長整型 long 來完成所有的計算,最后返回值乘以符號即可,代碼如下:

解法一:

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;
    }
};

我們可以通過遞歸的方法來解使上面的解法變得更加簡潔:

解法二:

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;
    }
};

關于C++中怎么利用LeetCode實現兩數相除就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

铅山县| 湾仔区| 积石山| 灵石县| 成武县| 永仁县| 道真| 且末县| 阳曲县| 松阳县| 泸溪县| 荔波县| 平安县| 永昌县| 内黄县| 枞阳县| 尚义县| 油尖旺区| 左贡县| 获嘉县| 隆尧县| 江川县| 兖州市| 介休市| 赤壁市| 沁水县| 汕头市| 鹿泉市| 成都市| 徐汇区| 平潭县| 囊谦县| 垣曲县| 太康县| 蓬莱市| 三亚市| 应用必备| 灵宝市| 琼海市| 仪陇县| 同心县|