首頁 > 軟體

後端演演算法題解LeetCode字首和範例詳解

2022-10-02 14:01:04

面試題 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 是新字串的子串;

比如,s1abcds2cdab,然後兩個 s1 拼接成 abcdabcd這個新字串 s3,可以發現 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. 一維陣列的動態和

1480. 一維陣列的動態和 難度:easy

給你一個陣列 nums 。陣列「動態和」的計算公式為:runningSum[i] = sum(nums[0]…nums[i])

請返回 nums 的動態和。

範例 1:

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

範例 2:

輸入:nums = [1,1,1,1,1]
輸出:[1,2,3,4,5]
解釋:動態和計算過程為 [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

方法一:字首和

思路

這題比較基礎,適合用於瞭解什麼是字首和,以及初步的嘗試使用字首和;

根據題目意思,是要求陣列的動態和,即當前數應該等於這個數的舊值和前面一個值的和,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. 尋找陣列的中心下標

724. 尋找陣列的中心下標 難度:easy

給你一個整數陣列 nums ,請計算陣列的 中心下標

陣列 中心下標 是陣列的一個下標,其左側所有元素相加的和等於右側所有元素相加的和。

如果中心下標位於陣列最左端,那麼左側數之和視為 0 ,因為在下標的左側不存在元素。這一點對於中心下標位於陣列最右端同樣適用。

如果陣列有多箇中心下標,應該返回 最靠近左邊 的那一個。如果陣列不存在中心下標,返回 -1

範例 1:

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

範例 2:

輸入:nums = [1, 2, 3]
輸出:-1
解釋:
陣列中不存在滿足此條件的中心下標。

範例 3:

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

提示:

1 <= nums.length <= 104

-1000 <= nums[i] <= 1000

方法一:字首和

思路

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

# 假設 fn 為陣列的動態和
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字首和的資料請關注it145.com其它相關文章!


IT145.com E-mail:sddin#qq.com