public static void main(String[] args) {
System.out.println(hasPairWithSum(new int[] { 12, 4, 3, 4, 1, 7 }, 9));
System.out.println(hasPairWithSum2(new int[] { 12, 4, 3, 4, 1, 7 }, 9));
System.out.println(hasPairWithSum3(new int[] { 12, 4, 3, 4, 1, 7 }, 9));
}
public static boolean hasPairWithSum(int[] intArray, int sum) {
int len = intArray.length;
for (int i = 0; i < len - 1; i++) {
for (int j = i + 1; j < len; j++) {
if (intArray[i] + intArray[j] == sum) {
return true;
}
}
}
return false;
}
public static boolean hasPairWithSum2(int[] intArray, int sum) {
HashSet<Integer> mySet = new HashSet<Integer>();
int len = intArray.length;
for (int i = 0; i < len; i++) {
if (mySet.contains(intArray[i])) {
return true;
}
mySet.add(sum - intArray[i]);
}
return false;
}
public static boolean hasPairWithSum3(int[] intArray, int sum) {
HashSet<Integer> mySet = new HashSet<Integer>();
int len = intArray.length;
return IntStream.range(0, len).mapToObj(i -> {
if (mySet.contains(intArray[i])) {
return true;
}
mySet.add(sum - intArray[i]);
return false;
}) != null;
}