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

后端算法題解LeetCode前綴和示例詳解

 更新時間:2022年09月30日 09:34:27   作者:????????????  
這篇文章主要為大家介紹了后端算法題解LeetCode前綴和示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

面試題 01.09. 字符串輪轉

面試題 01.09. 字符串輪轉 難度:easy

字符串輪轉。給定兩個字符串 s1s2,請編寫代碼檢查 s2 是否為 s1 旋轉而成(比如,waterbottleerbottlewat 旋轉后的字符串)。

示例1:

輸入:s1 = "waterbottle", s2 = "erbottlewat"
輸出:True

示例2:

輸入:s1 = "aa", s2 = "aba"
輸出:False

提示:

  • 字符串長度在 [0, 100000] 范圍內。

方法一:模擬

思路

通過模擬字符串輪轉的過程,來進行字符串的比較,最后得出結論,s2 是否為 s1 旋轉而成;

首先比較字符串的長度,如果兩個字符串的長度都不一樣,那肯定就不是有旋轉而成的,偽代碼如下:

if len(s1) != len(s2):
    return False
else:
    ...
    # 接著往下走

然后再通過遍歷將倆字符串進行一一比較,比如指針先指向 s1 的第一位,移動 s2 直到找到與之匹配的,再接著往下,如果不對則結束接下來的匹配,然后將指針指向 s1 的下一位,如此往復,一直到遍歷完 s1,偽代碼如下:

for ..s1:
    for ..s2:
        if s1[(i + j) % n] != s2[j]:
            break
    else:
        return True

題解

Python:

class Solution:
    def isFlipedString(self, s1: str, s2: str) -> bool:
        m, n = len(s1), len(s2)
        if m != n:
            return False
        if n == 0:
            return True
        for i in range(n):
            for j in range(n):
                if s1[(i + j) % n] != s2[j]:
                    break
            else:
                return True
        return False

Java:

class Solution {
    public boolean isFlipedString(String s1, String s2) {
        int m = s1.length(), n = s2.length();
        if (m != n) {
            return false;
        }
        if (n == 0) {
            return true;
        }
        for (int i = 0; i < n; i++) {
            boolean flag = true;
            for (int j = 0; j < n; j++) {
                if (s1.charAt((i + j) % n) != s2.charAt(j)) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                return true;
            }
        }
        return false;
    }
}

方法二:搜索子字符串

思路

通過將兩個相同的 s1 進行拼接,獲得新的字符串,然后從這個新的字符串中搜索 s2,即 s2 是新字符串的子串;

比如,s1abcd,s2cdab,然后兩個 s1 拼接成 abcdabcd這個新字符串 s3,可以發(fā)現(xiàn) s2 就是 s3 的子串,如果 s1 無法通過旋轉得到 s2,那么自然就不是 s3 的子串了,所以偽代碼如下:

s3 = s1 + s1
if s2 in s3:
    return True
else:
    return False

題解

Python:

class Solution:
    def isFlipedString(self, s1: str, s2: str) -> bool:
        return len(s1) == len(s2) and s2 in s1 + s1

Java:

class Solution {
    public boolean isFlipedString(String s1, String s2) {
        return s1.length() == s2.length() && (s1 + s1).contains(s2);
    }
}

1480. 一維數(shù)組的動態(tài)和

1480. 一維數(shù)組的動態(tài)和 難度:easy

給你一個數(shù)組 nums 。數(shù)組「動態(tài)和」的計算公式為:runningSum[i] = sum(nums[0]…nums[i]) 。

請返回 nums 的動態(tài)和。

示例 1:

輸入:nums = [1,2,3,4]
輸出:[1,3,6,10]
解釋:動態(tài)和計算過程為 [1, 1+2, 1+2+3, 1+2+3+4] 。

示例 2:

輸入:nums = [1,1,1,1,1]
輸出:[1,2,3,4,5]
解釋:動態(tài)和計算過程為 [1, 1+1, 1+1+1, 1+1+1+1, 1+1+1+1+1] 。

示例 3:

輸入:nums = [3,1,2,10,1]
輸出:[3,4,6,16,17]  

提示:

1 <= nums.length <= 1000

-10^6 <= nums[i] <= 10^6

方法一:前綴和

思路

這題比較基礎,適合用于了解什么是前綴和,以及初步的嘗試使用前綴和;

根據(jù)題目意思,是要求數(shù)組的動態(tài)和,即當前數(shù)應該等于這個數(shù)的舊值和前面一個值的和,fn = fn + fn-1;

題解

Python:

class Solution:
    def runningSum(self, nums: List[int]) -> List[int]:
        n = len(nums)
        for i in range(1, n):
            nums[i] += nums[i - 1]
        return nums

Java:

class Solution {
    public int[] runningSum(int[] nums) {
        int n = nums.length;
        for (int i = 1; i < n; i++) {
            nums[i] += nums[i - 1];
        }
        return nums;
    }
}

724. 尋找數(shù)組的中心下標

724. 尋找數(shù)組的中心下標 難度:easy

給你一個整數(shù)數(shù)組 nums ,請計算數(shù)組的 中心下標 。

數(shù)組 中心下標 是數(shù)組的一個下標,其左側所有元素相加的和等于右側所有元素相加的和。

如果中心下標位于數(shù)組最左端,那么左側數(shù)之和視為 0 ,因為在下標的左側不存在元素。這一點對于中心下標位于數(shù)組最右端同樣適用。

如果數(shù)組有多個中心下標,應該返回 最靠近左邊 的那一個。如果數(shù)組不存在中心下標,返回 -1

示例 1:

輸入:nums = [1, 7, 3, 6, 5, 6]
輸出:3
解釋:
中心下標是 3 。
左側數(shù)之和 sum = nums[0] + nums[1] + nums[2] = 1 + 7 + 3 = 11 ,
右側數(shù)之和 sum = nums[4] + nums[5] = 5 + 6 = 11 ,二者相等。

示例 2:

輸入:nums = [1, 2, 3]
輸出:-1
解釋:
數(shù)組中不存在滿足此條件的中心下標。

示例 3:

輸入:nums = [2, 1, -1]
輸出:0
解釋:
中心下標是 0 。
左側數(shù)之和 sum = 0 ,(下標 0 左側不存在元素),
右側數(shù)之和 sum = nums[1] + nums[2] = 1 + -1 = 0 。  

提示:

1 <= nums.length <= 104

-1000 <= nums[i] <= 1000

方法一:前綴和

思路

題目要求我們尋找一個中心點,使得左邊之和與右邊之和相等,其實跟上一題的思路是相似的,也就是求數(shù)組的動態(tài)和,要等于總和 total 減去當前的數(shù)值 nums[i] 再除以2(因為左右要相等),偽代碼如下:

# 假設 fn 為數(shù)組的動態(tài)和
total == fn[i-1]*2 + nums[i] ? True : False

解題

Python:

class Solution:
    def pivotIndex(self, nums: List[int]) -> int:
        total = sum(nums)
        _sum = 0
        for i in range(len(nums)):
            if total == _sum * 2 + nums[i]: return i
            _sum += nums[i]
        return -1

Java:

class Solution {
    public int pivotIndex(int[] nums) {
        int total = Arrays.stream(nums).sum();
        int sum = 0;
        for (int i = 0; i < nums.length; ++i) {
            if (2 * sum + nums[i] == total) {
                return i;
            }
            sum += nums[i];
        }
        return -1;
    }
}

以上就是后端算法題解LeetCode前綴和示例詳解的詳細內容,更多關于后端算法題解LeetCode前綴和的資料請關注腳本之家其它相關文章!

相關文章

  • vim中tagbar配置以及打字時隱藏鼠標的方法

    vim中tagbar配置以及打字時隱藏鼠標的方法

    這篇文章主要給大家介紹了關于vim中tagbar配置以及打字時隱藏鼠標的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • 漢明碼編碼原理及校驗方法分析

    漢明碼編碼原理及校驗方法分析

    漢明碼在傳輸?shù)南⒘髦胁迦腧炞C碼,當計算機存儲或移動數(shù)據(jù)時,可能會產生數(shù)據(jù)位錯誤,以偵測并更正單一比特錯誤。由于漢明編碼簡單,它們被廣泛應用于內存RAM
    2021-09-09
  • vs2019+cmake實現(xiàn)Linux遠程開發(fā)的方法步驟

    vs2019+cmake實現(xiàn)Linux遠程開發(fā)的方法步驟

    這篇文章主要介紹了vs2019+cmake實現(xiàn)Linux遠程開發(fā)的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Dreamweaver中如何設定文字大小、字體、顏色

    Dreamweaver中如何設定文字大小、字體、顏色

    這篇文章主要給大家介紹了關于Dreamweaver中如何設定文字大小、字體、顏色的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2007-06-06
  • 一個假冒的序列號被用來注冊Internet?Download?Manager,IDM正在退出的解決辦法

    一個假冒的序列號被用來注冊Internet?Download?Manager,IDM正在退出的解決辦法

    這篇文章主要介紹了一個假冒的序列號被用來注冊Internet?Download?Manager?IDM正在退出的解決辦法,在文章末尾給大家分享了序列號和綠色軟件,大家根據(jù)自身情況選擇,需要的朋友可以參考下
    2023-01-01
  • 踩坑記錄關于"authentication failed "的解決方法

    踩坑記錄關于"authentication failed "的解決方法

    今天給大家分享我的踩坑記錄關于報錯 authentication failed,這個報錯的原因是“身份驗證失敗”,本文給大家分享我的解決方法,感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • 如何用Idea或者webstorm跑一個Vue項目(步驟詳解)

    如何用Idea或者webstorm跑一個Vue項目(步驟詳解)

    這篇文章主要介紹了如何用Idea或者webstorm跑一個Vue項目,本文分步驟給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • 盤點網絡編程必須要知道的基礎知識

    盤點網絡編程必須要知道的基礎知識

    這篇文章主要介紹了盤點網絡編程必須要知道的基礎知識,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2020-07-07
  • MobaXterm詳細使用圖文教程(MobaXterm連接Linux服務器)

    MobaXterm詳細使用圖文教程(MobaXterm連接Linux服務器)

    這篇文章主要介紹了MobaXterm詳細使用教程,介紹一下如何設置并用MobaXterm來連接Linux服務器,本文介紹了三種連接方式:SSH,F(xiàn)TP,serial,以及幾個有用的設置和命令,需要的朋友可以參考下
    2023-05-05
  • 人人都能看懂的 6 種限流實現(xiàn)方案(純干貨)

    人人都能看懂的 6 種限流實現(xiàn)方案(純干貨)

    這篇文章主要介紹了人人都能看懂的 6 種限流實現(xiàn)方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05

最新評論