LeetCode217——存在重复元素
1.题目描述:
给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false 。
2.Result01(暴力解)
public static boolean containsDuplicate(int[] nums) {//暴力解 会超时for (int i = 0; i < nums.length; i++) {for (int j = i + 1; j < nums.length; j++) {if (nums[i] == nums[j]) {return true;}}}return false;}
结果是对的,但是时间复杂度O(N2)跑出来会超时哈哈哈。
3.Result02(先排序、后比较)
相对于暴力解来说降低了时间复杂度。
public static boolean containsDuplicate(int[] arr){//先排序 在比较 一次for就行Arrays.sort(arr);for (int i = 0; i < arr.length-1; i++) {if (arr[i]==arr[i+1]){return true;}}return false;}
4.Result03(哈希)
Set集合中 无序 且 不能存在重复元素 利用这一特性解决此题。
相对于排序后在比较的解法,哈希法又降低了时间复杂度——(O(N))。
public static boolean containsDuplicate(int[] arr){//Set集合无序 且 不能有重复元素!HashSet<Integer> hashSet = new HashSet<Integer>();for (int i:arr) {if (! hashSet.add(i)){//add()方法的返回值是boolean类型的 成功添加 true 未成功 falsereturn true;}}return false;}