สมมติว่าเรามีรายการไบนารีที่มี 0s หรือ 1s นอกจากนี้เรายังมีอินพุตอื่นที่เรียกว่า k เราต้องหาจำนวนรายการย่อยที่มีผลรวมเท่ากับ k
ดังนั้น หากอินพุตมีค่าเท่ากับ nums =[1, 0, 0, 1, 1, 1, 0, 1] k =3 ผลลัพธ์จะเป็น 8 เนื่องจากรายการย่อยคือ [1,0,0,1,1 ], [0,0,1,1,1], [0,0,1,1,1,0], [0,1,1,1], [0,1,1,1,0], [1,1,1], [1,1,1,0] [1,1,0,1].
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
- ผลรวม :=ในแผนที่แรกประกอบด้วย valye 1 สำหรับคีย์ 0
- r_sum :=0
- ตอบ :=0
- สำหรับแต่ละ x เป็น nums ทำ
- r_sum :=r_sum + x
- ans :=ans + (sums[r_sum - k] ถ้า (r_sum - k) มี มิฉะนั้น 0)
- sums[r_sum] :=1 + (sums[r_sum - k] ถ้า (r_sum - k) มี มิฉะนั้น 0)
- คืนสินค้า
ตัวอย่าง
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
def solve(nums, k): sums = {0: 1} r_sum = 0 ans = 0 for x in nums: r_sum += x ans += sums.get(r_sum - k, 0) sums[r_sum] = sums.get(r_sum, 0) + 1 return ans nums = [1, 0, 0, 1, 1, 1, 0, 1] k = 3 print(solve(nums, k))
อินพุต
[1, 0, 0, 1, 1, 1, 0, 1], 3
ผลลัพธ์
8