LeetCode 303,560,1248 (前缀求和 )
303. 區域和檢索 - 數組不可變
給定一個整數數組 nums,求出數組從索引 i 到 j (i ≤ j) 范圍內元素的總和,包含 i, j 兩點。
示例:
給定 nums = [-2, 0, 3, -5, 2, -1],求和函數為 sumRange()
sumRange(0, 2) -> 1
sumRange(2, 5) -> -1
sumRange(0, 5) -> -3
說明:
你可以假設數組不可變。
會多次調用 sumRange 方法。
Code 303
type NumArray struct {Value []int }func Constructor(nums []int) NumArray {arr := NumArray{[]int{0}} // 浪費第一個空間// 1, 2, 3, 4, 5for i, v := range nums {// 1, 3, 6, 10, 15arr.Value = append(arr.Value, v + arr.Value[i])}return arr }func (this *NumArray) SumRange(i int, j int) int {// i = 0; j = 3 // [3+1] - [0] = 15 - 1 = 14 = 1 + 2 + 3 + 4 return this.Value[j+1] - this.Value[i] }560. 和為K的子數組
給定一個整數數組和一個整數 k,你需要找到該數組中和為 k 的連續的子數組的個數。
示例 1 :
輸入:nums = [1,1,1], k = 2
輸出: 2 , [1,1] 與 [1,1] 為兩種不同的情況。
說明 :
數組的長度為 [1, 20,000]。
數組中元素的范圍是 [-1000, 1000] ,且整數 k 的范圍是 [-1e7, 1e7]。
Code 560
func subarraySum(nums []int, k int) int { res , m , sum := 0, make(map[int]int,0),0m[0] = 1for i:=0;i<len(nums);i++{sum += nums[i]if _,ok := m[sum-k];ok{res += m[sum-k]}m[sum]++}return res }1248. 統計「優美子數組」
給你一個整數數組 nums 和一個整數 k。
如果某個 連續 子數組中恰好有 k 個奇數數字,我們就認為這個子數組是「優美子數組」。
請返回這個數組中「優美子數組」的數目。
示例 1:
輸入:nums = [1,1,2,1,1], k = 3
輸出:2
解釋:包含 3 個奇數的子數組是 [1,1,2,1] 和 [1,2,1,1] 。
示例 2:
輸入:nums = [2,4,6], k = 1
輸出:0
解釋:數列中不包含任何奇數,所以不存在優美子數組。
示例 3:
輸入:nums = [2,2,2,1,2,2,1,2,2,2], k = 2
輸出:16
提示:
1 <= nums.length <= 50000
1 <= nums[i] <= 10^5
1 <= k <= nums.length
Code 1248
這個題,嚴格來說是動態規劃的范疇!
總結
以上是生活随笔為你收集整理的LeetCode 303,560,1248 (前缀求和 )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 466. 统计重复个数 golang[转
- 下一篇: DNF稀有装扮冥光天羽套如何获得?