日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode 303,560,1248 (前缀求和 )

發布時間:2023/11/30 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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

這個題,嚴格來說是動態規劃的范疇!

func numberOfSubarrays(nums []int, k int) int {dp := make([]int, 0)cnt, ret := 0, 0for i := 0; i < len(nums); i++ {cnt++// 每次遇到奇數。記錄他前面的偶數個數if nums[i]%2 == 1 {dp = append(dp, cnt)cnt = 0}if len(dp) >= k {ret += dp[len(dp) - k]}}return ret }

總結

以上是生活随笔為你收集整理的LeetCode 303,560,1248 (前缀求和 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。