two sum问题一直ignore的一个细节就是要check target-value[i]是不是map向同一个数字..而这个数字是否只存在一个...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 | public class TwoSum {
HashMap<Integer, Integer>lookup = new HashMap<Integer, Integer>();
ArrayList<Integer> numbers = new ArrayList<Integer>();
public void add(int number) {
int count = 1;
if (lookup.containsKey(number)) count += lookup.get(number);
lookup.put(number, count);
numbers.add(number);
}
public boolean find(int value) {
for (int i = 0; i < numbers.size(); i++){
int target = value-numbers.get(i);
if (target == numbers.get(i)){
if (lookup.containsKey(target) && lookup.get(target) >= 2){
return true;
}
}else if (lookup.containsKey(target)) return true;
}
return false;
}
}
|
No comments:
Post a Comment