LeetCode - 523. Continuous Subarray Sum
Medium
寫完這題去寫 974. Subarray Sums Divisible by K 吧!思路很像,可以來個 double kill
974. Subarray Sums Divisible by K題目
Given an integer array nums and an integer k, return true if nums has a good subarray or false otherwise.
A good subarray is a subarray where:
- its length is at least two, and
- the sum of the elements of the subarray is a multiple of
k.
Note that:
- A subarray is a contiguous part of the array.
- An integer
xis a multiple ofkif there exists an integernsuch thatx = n * k.0is always a multiple ofk.
Example 1:
Input: nums = [23,2,4,6,7], k = 6
Output: true
Explanation: [2, 4] is a continuous subarray of size 2 whose elements sum up to 6.
Example 2:
Input: nums = [23,2,6,4,7], k = 6
Output: true
Explanation: [23, 2, 6, 4, 7] is an continuous subarray of size 5 whose elements sum up to 42.42 is a multiple of 6 because 42 = 7 * 6 and 7 is an integer.
Example 3:
Input: nums = [23,2,6,4,7], k = 13
Output: false
Constraints:
1 <= nums.length <=0 <= nums[i] <=0 <= sum(nums[i]) <=- 11 <= k <=- 1
解題思路
用前綴和的餘數,可以推出哪個區間之內的和可以被整除
利用 prefixSum % k 的餘數,如果有別格與他相減 == 0 且這兩格之間不只差 1,就可以確定這區間和是 k 的倍數
思路公式如下:prefix[j] = Q1 * k + R1, prefix[i] = Q2 * k + R2
((Q1 - Q2) * k + (R1 - R2)) % k == 0
prefix[j] % k == prefix[i] % k
Solution Code
1 | class Solution { |