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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

LeetCode简单题之差的绝对值为 K 的数对数目

發布時間:2023/11/28 生活经验 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode简单题之差的绝对值为 K 的数对数目 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目

給你一個整數數組 nums 和一個整數 k ,請你返回數對 (i, j) 的數目,滿足 i < j 且 |nums[i] - nums[j]| == k 。
|x| 的值定義為:
如果 x >= 0 ,那么值為 x 。
如果 x < 0 ,那么值為 -x 。
示例 1:
輸入:nums = [1,2,2,1], k = 1
輸出:4
解釋:差的絕對值為 1 的數對為:

  • [1,2,2,1]
  • [1,2,2,1]
  • [1,2,2,1]
  • [1,2,2,1]
    示例 2:
    輸入:nums = [1,3], k = 3
    輸出:0
    解釋:沒有任何數對差的絕對值為 3 。
    示例 3:
    輸入:nums = [3,2,1,5,4], k = 2
    輸出:3
    解釋:差的絕對值為 2 的數對為:
  • [3,2,1,5,4]
  • [3,2,1,5,4]
  • [3,2,1,5,4]
    提示:
    1 <= nums.length <= 200
    1 <= nums[i] <= 100
    1 <= k <= 99
    來源:力扣(LeetCode)

解題思路

??根據題目的意思,我們需要尋找兩數之差絕對值等于k的值,故兩個數是對稱對等的關系。按照示例1的做法,每次訪問當前元素并試圖查找符合條件的另一個元素時,都是往后尋找的例如第一對,1和2,找完1,當遍歷到2的時候便不再計算2和1是一對了,所有1和2,或者2和1是對稱等價的,只需要計算一對即可。那么,為了能夠加速計算,我們利用哈希表計算2和1這一對。這是一個非常巧妙地思想,在前面的兩數之和也出現過。

class Solution:def countKDifference(self, nums: List[int], k: int) -> int:d={}ans=0for i in nums:ans+=d.get(i+k,0)+d.get(i-k,0)d[i]=d.get(i,0)+1return ans

總結

以上是生活随笔為你收集整理的LeetCode简单题之差的绝对值为 K 的数对数目的全部內容,希望文章能夠幫你解決所遇到的問題。

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