欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實(shí)現(xiàn)LeetCode(29.兩數(shù)相除)

 更新時(shí)間:2021年07月14日 09:42:29   作者:Grandyang  
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(29.兩數(shù)相除),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[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ì)于這種情況就在開(kāi)始用 if 判定,將其和除數(shù)為0的情況放一起判定,返回 INT_MAX。然后還要根據(jù)被除數(shù)和除數(shù)的正負(fù)來(lái)確定返回值的正負(fù),這里采用長(zhǎng)整型 long 來(lái)完成所有的計(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;
    }
};

我們可以通過(guò)遞歸的方法來(lái)解使上面的解法變得更加簡(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表的查找和建立

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表的查找和建立

    鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的。本文將和大家一起聊聊C語(yǔ)言中單鏈表的查找和建立,感興趣的可以學(xué)習(xí)一下
    2022-09-09
  • C++ 中Vector常用基本操作

    C++ 中Vector常用基本操作

    標(biāo)準(zhǔn)庫(kù)vector類型是C++中使用較多的一種類模板,本文給大家分享C++ 中Vector常用基本操作,感興趣的朋友一起看看吧
    2017-10-10
  • OpenCV實(shí)現(xiàn)拼圖算法

    OpenCV實(shí)現(xiàn)拼圖算法

    這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)拼圖算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C++淺析內(nèi)存分區(qū)模型概念與示例

    C++淺析內(nèi)存分區(qū)模型概念與示例

    在了解內(nèi)存分區(qū)之前,我們先來(lái)聊一聊為什么要進(jìn)行內(nèi)存分區(qū)。在進(jìn)行了內(nèi)存分區(qū)之后,在不同的區(qū)域存放的數(shù)據(jù),會(huì)有不同的生命周期,從而會(huì)讓程序員的編程變得更加靈活
    2022-09-09
  • C語(yǔ)言中指針和數(shù)組試題詳解分析

    C語(yǔ)言中指針和數(shù)組試題詳解分析

    變量存放在內(nèi)存中,內(nèi)存其實(shí)就是一組有序字節(jié)組成的數(shù)組,每個(gè)字節(jié)有唯一的內(nèi)存地址。CPU 通過(guò)內(nèi)存尋址對(duì)存儲(chǔ)在內(nèi)存中的某個(gè)指定數(shù)據(jù)對(duì)象的地址進(jìn)行定位。數(shù)據(jù)對(duì)象是指存儲(chǔ)在內(nèi)存中的一個(gè)指定數(shù)據(jù)類型的數(shù)值或字符串,它們都有一個(gè)自己的地址,指針是保存這個(gè)地址的變量
    2021-10-10
  • 解析C++函數(shù)的默認(rèn)參數(shù)和占位參數(shù)及較之C語(yǔ)言的拓展

    解析C++函數(shù)的默認(rèn)參數(shù)和占位參數(shù)及較之C語(yǔ)言的拓展

    這篇文章主要介紹了C++中的默認(rèn)參數(shù)和占位參數(shù)及較之C語(yǔ)言的拓展,需要的朋友可以參考下
    2016-03-03
  • C++實(shí)現(xiàn)基于不相交集合的O(mlgn)復(fù)雜度的kruskal算法

    C++實(shí)現(xiàn)基于不相交集合的O(mlgn)復(fù)雜度的kruskal算法

    這篇文章主要為大家詳細(xì)介紹了C++如何實(shí)現(xiàn)基于不相交集合的O(mlgn)復(fù)雜度的kruskal算法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2023-02-02
  • opencv如何識(shí)別圖片上帶顏色的圓

    opencv如何識(shí)別圖片上帶顏色的圓

    這篇文章主要為大家詳細(xì)介紹了opencv如何識(shí)別圖片上帶顏色的圓,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • php調(diào)用c++的方法

    php調(diào)用c++的方法

    這篇文章主要介紹了php調(diào)用c++的方法,需要的朋友可以參考下
    2014-01-01
  • C++中的for-each循環(huán)使用

    C++中的for-each循環(huán)使用

    范圍循環(huán)是C++11引入的特性,用于簡(jiǎn)化數(shù)組和容器的遍歷過(guò)程,它通過(guò)直接操作元素而不是使用索引或迭代器,范圍循環(huán)可以使用引用或const修飾符來(lái)控制元素的修改權(quán)限,適用于所有支持begin()和end()方法的容器,該循環(huán)方式不適用于未提供這些方法的C++98/03容器
    2024-09-09

最新評(píng)論