1865:找出和为指定值的下标对

This commit is contained in:
huangge1199 2021-06-07 13:10:07 +08:00
parent 73d80b1da7
commit a4f80ae13f
2 changed files with 164 additions and 0 deletions

View File

@ -0,0 +1,112 @@
//给你两个整数数组 nums1 nums2 请你实现一个支持下述两类查询的数据结构
//
//
// 累加 将一个正整数加到 nums2 中指定下标对应元素上
// 计数 统计满足 nums1[i] + nums2[j] 等于指定值的下标对 (i, j) 数目0 <= i < nums1.length 0 <=
// j < nums2.length
//
//
// 实现 FindSumPairs
//
//
// FindSumPairs(int[] nums1, int[] nums2) 使用整数数组 nums1 nums2 初始化 FindSumPairs
//对象
// void add(int index, int val) val 加到 nums2[index] 执行 nums2[index] += val
//
// int count(int tot) 返回满足 nums1[i] + nums2[j] == tot 的下标对 (i, j) 数目
//
//
//
//
// 示例
//
//
//输入
//["FindSumPairs", "count", "add", "count", "count", "add", "add", "count"]
//[[[1, 1, 2, 2, 2, 3], [1, 4, 5, 2, 5, 4]], [7], [3, 2], [8], [4], [0, 1], [1,
//1], [7]]
//输出
//[null, 8, null, 2, 1, null, null, 11]
//
//解释
//FindSumPairs findSumPairs = new FindSumPairs([1, 1, 2, 2, 2, 3], [1, 4, 5, 2,
//5, 4]);
//findSumPairs.count(7); // 返回 8 ; 下标对 (2,2), (3,2), (4,2), (2,4), (3,4), (4,4)
// 满足 2 + 5 = 7 下标对 (5,1), (5,5) 满足 3 + 4 = 7
//findSumPairs.add(3, 2); // 此时 nums2 = [1,4,5,4,5,4]
//findSumPairs.count(8); // 返回 2 下标对 (5,2), (5,4) 满足 3 + 5 = 8
//findSumPairs.count(4); // 返回 1 下标对 (5,0) 满足 3 + 1 = 4
//findSumPairs.add(0, 1); // 此时 nums2 = [2,4,5,4,5,4]
//findSumPairs.add(1, 1); // 此时 nums2 = [2,5,5,4,5,4]
//findSumPairs.count(7); // 返回 11 下标对 (2,1), (2,2), (2,4), (3,1), (3,2), (3,4)
//, (4,1), (4,2), (4,4) 满足 2 + 5 = 7 下标对 (5,3), (5,5) 满足 3 + 4 = 7
//
//
//
//
// 提示
//
//
// 1 <= nums1.length <= 1000
// 1 <= nums2.length <= 105
// 1 <= nums1[i] <= 109
// 1 <= nums2[i] <= 105
// 0 <= index < nums2.length
// 1 <= val <= 105
// 1 <= tot <= 109
// 最多调用 add count 函数各 1000
//
// Related Topics 设计 哈希表 Ordered Map
// 👍 9 👎 0
package leetcode.editor.cn;
import java.util.HashMap;
import java.util.Map;
//1865:找出和为指定值的下标对
public class FindingPairsWithACertainSum{
public static void main(String[] args) {
//测试代码
// Solution solution = new FindingPairsWithACertainSum().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class FindSumPairs {
int[] nums1;
int[] nums2;
Map<Integer, Integer> map = new HashMap<>();
public FindSumPairs(int[] nums1, int[] nums2) {
this.nums1 = nums1;
this.nums2 = nums2;
for (int i = 0; i < nums2.length; i++) {
map.put(nums2[i], map.getOrDefault(nums2[i], 0) + 1);
}
}
public void add(int index, int val) {
map.put(nums2[index], map.getOrDefault(nums2[index], 0) - 1);
map.put(nums2[index] + val, map.getOrDefault(nums2[index] + val, 0) + 1);
nums2[index] += val;
}
public int count(int tot) {
int count = 0;
for (int i = 0; i < nums1.length; i++) {
count += map.getOrDefault(tot - nums1[i], 0);
}
return count;
}
}
/**
* Your FindSumPairs object will be instantiated and called as such:
* FindSumPairs obj = new FindSumPairs(nums1, nums2);
* obj.add(index,val);
* int param_2 = obj.count(tot);
*/
//leetcode submit region end(Prohibit modification and deletion)
}

View File

@ -0,0 +1,52 @@
<p>给你两个整数数组 <code>nums1</code><code>nums2</code> ,请你实现一个支持下述两类查询的数据结构:</p>
<ol>
<li><strong>累加</strong> ,将一个正整数加到 <code>nums2</code> 中指定下标对应元素上。</li>
<li><strong>计数 </strong>,统计满足 <code>nums1[i] + nums2[j]</code> 等于指定值的下标对 <code>(i, j)</code> 数目(<code>0 <= i < nums1.length</code><code>0 <= j < nums2.length</code>)。</li>
</ol>
<p>实现 <code>FindSumPairs</code> 类:</p>
<ul>
<li><code>FindSumPairs(int[] nums1, int[] nums2)</code> 使用整数数组 <code>nums1</code><code>nums2</code> 初始化 <code>FindSumPairs</code> 对象。</li>
<li><code>void add(int index, int val)</code><code>val</code> 加到 <code>nums2[index]</code> 上,即,执行 <code>nums2[index] += val</code></li>
<li><code>int count(int tot)</code> 返回满足 <code>nums1[i] + nums2[j] == tot</code> 的下标对 <code>(i, j)</code> 数目。</li>
</ul>
<p> </p>
<p><strong>示例:</strong></p>
<pre>
<strong>输入:</strong>
["FindSumPairs", "count", "add", "count", "count", "add", "add", "count"]
[[[1, 1, 2, 2, 2, 3], [1, 4, 5, 2, 5, 4]], [7], [3, 2], [8], [4], [0, 1], [1, 1], [7]]
<strong>输出:</strong>
[null, 8, null, 2, 1, null, null, 11]
<strong>解释:</strong>
FindSumPairs findSumPairs = new FindSumPairs([1, 1, 2, 2, 2, 3], [1, 4, 5, 2, 5, 4]);
findSumPairs.count(7); // 返回 8 ; 下标对 (2,2), (3,2), (4,2), (2,4), (3,4), (4,4) 满足 2 + 5 = 7 ,下标对 (5,1), (5,5) 满足 3 + 4 = 7
findSumPairs.add(3, 2); // 此时 nums2 = [1,4,5,<em><strong>4</strong></em><code>,5,4</code>]
findSumPairs.count(8); // 返回 2 ;下标对 (5,2), (5,4) 满足 3 + 5 = 8
findSumPairs.count(4); // 返回 1 ;下标对 (5,0) 满足 3 + 1 = 4
findSumPairs.add(0, 1); // 此时 nums2 = [<em><strong><code>2</code></strong></em>,4,5,4<code>,5,4</code>]
findSumPairs.add(1, 1); // 此时 nums2 = [<code>2</code>,<em><strong>5</strong></em>,5,4<code>,5,4</code>]
findSumPairs.count(7); // 返回 11 ;下标对 (2,1), (2,2), (2,4), (3,1), (3,2), (3,4), (4,1), (4,2), (4,4) 满足 2 + 5 = 7 ,下标对 (5,3), (5,5) 满足 3 + 4 = 7
</pre>
<p> </p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 <= nums1.length <= 1000</code></li>
<li><code>1 <= nums2.length <= 10<sup>5</sup></code></li>
<li><code>1 <= nums1[i] <= 10<sup>9</sup></code></li>
<li><code>1 <= nums2[i] <= 10<sup>5</sup></code></li>
<li><code>0 <= index < nums2.length</code></li>
<li><code>1 <= val <= 10<sup>5</sup></code></li>
<li><code>1 <= tot <= 10<sup>9</sup></code></li>
<li>最多调用 <code>add</code><code>count</code> 函数各 <code>1000</code></li>
</ul>
<div><div>Related Topics</div><div><li>设计</li><li>哈希表</li><li>Ordered Map</li></div></div>\n<div><li>👍 9</li><li>👎 0</li></div>