[LeetCode] 170. Two Sum III - Data structure design

Design a data structure that accepts a stream of integers and checks if it has a pair of integers that sum up to a particular value.

Implement the TwoSum class:

  • TwoSum() Initializes the TwoSum object, with an empty array initially.
  • void add(int number) Adds number to the data structure.
  • boolean find(int value) Returns true if there exists any pair of numbers whose sum is equal to value, otherwise, it returns false.

Example 1:

Input
["TwoSum", "add", "add", "add", "find", "find"]
[[], [1], [3], [5], [4], [7]]
Output
[null, null, null, null, true, false]

Explanation
TwoSum twoSum = new TwoSum();
twoSum.add(1);   // [] --> [1]
twoSum.add(3);   // [1] --> [1,3]
twoSum.add(5);   // [1,3] --> [1,3,5]
twoSum.find(4);  // 1 + 3 = 4, return true
twoSum.find(7);  // No two integers sum up to 7, return false

Constraints:

  • -105 <= number <= 105
  • -231 <= value <= 231 - 1
  • At most 104 calls will be made to add and find.

两数之和 III - 数据结构设计。

Two Sum的变种,是一道设计题。实现两个函数 add() 和 find()。

思路是用 hashmap 存,遍历 input 的时候可以找 target - num1 是否存在于 hashmap,需要记得判断当 num1 + num2 === sum 时,若 num1 === num2,看 hashmap 里面 num 的 value 是否大于1。

Java实现

 1 class TwoSum {
 2     private HashMap<Integer, Integer> map;
 3     private List<Integer> list;
 4     /** Initialize your data structure here. */
 5     public TwoSum() {
 6         map = new HashMap<>();
 7         list = new ArrayList<>();
 8     }
 9 
10     /** Add the number to an internal data structure.. */
11     public void add(int number) {
12         if (!map.containsKey(number)) {
13             map.put(number, 1);
14             list.add(number);
15         } else {
16             map.put(number, map.get(number) + 1);
17         }
18     }
19 
20     /** Find if there exists any pair of numbers which sum is equal to the value. */
21     public boolean find(int value) {
22         for (int num1 : list) {
23             int num2 = value - num1;
24             if ((num1 == num2 && map.get(num1) > 1) || (num1 != num2 && map.containsKey(num2))) {
25                 return true;
26             }
27         }
28         return false;
29     }
30 }
31 
32 /**
33  * Your TwoSum object will be instantiated and called as such:
34  * TwoSum obj = new TwoSum();
35  * obj.add(number);
36  * boolean param_2 = obj.find(value);
37  */

 

JavaScript实现

 1 /**
 2  * Initialize your data structure here.
 3  */
 4 var TwoSum = function() {
 5     this.map = {};
 6 };
 7 
 8 /**
 9  * Add the number to an internal data structure..
10  * @param {number} number
11  * @return {void}
12  */
13 TwoSum.prototype.add = function(number) {
14     if (this.map[number]) {
15         this.map[number]++;
16     } else {
17         this.map[number] = 1;
18     }
19 };
20 
21 /**
22  * Find if there exists any pair of numbers which sum is equal to the value.
23  * @param {number} value
24  * @return {boolean}
25  */
26 TwoSum.prototype.find = function(value) {
27     for (var key in this.map) {
28         var num1 = key;
29         var num2 = value - key;
30         if (this.map[num2]) {
31             if (num1 != num2 || this.map[num2] > 1) {
32                 return true;
33             }
34         }
35     }
36     return false;
37 };
38 
39 /**
40  * Your TwoSum object will be instantiated and called as such:
41  * var obj = new TwoSum()
42  * obj.add(number)
43  * var param_2 = obj.find(value)
44  */

 

two sum题目总结

LeetCode 题目总结

posted @ 2019-10-09 00:25  CNoodle  阅读(181)  评论(0编辑  收藏  举报