一、题目
给定一个整数数组,判断是否存在重复元素。
如果任意一值在数组中出现至少两次,函数返回 true 。如果数组中每个元素都不相同,则返回 false 。
示例 1:
输入: [1,2,3,1]
输出: true
示例 2:
输入: [1,2,3,4]
输出: false
示例 3:
输入: [1,1,1,3,3,4,3,2,4,2]
输出: true
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/contains-duplicate
二、java解法
1.哈希表
class Solution {
public boolean containsDuplicate(int[] nums) {
Map<Integer, Integer> hashtable = new HashMap<Integer, Integer>();
for (int i = 0; i < nums.length; ++i) {
if (hashtable.containsKey(nums[i])) {
return true;
}
hashtable.put(nums[i], i);
}
return false;
}
}
思路:依次将数组里面的元素放入哈希表中,每次插入的时候检查哈希表中是否存在重复元素,存在则返回true,不存在则返回false。
2.去重后比较长度
class Solution {
public boolean containsDuplicate(int[] nums) {
return Arrays.stream(nums).distinct().count() != nums.length;
}
}
class Solution {
public boolean containsDuplicate(int[] nums) {
Set<Integer> res = new HashSet<Integer>();
for(int i:nums)
res.add(i);
return res.size()<nums.length?true:false;
}
}
思路:用java自带的算法去重,然后比较数组长度,如果长度减小说明有重复元素
3.排序法
class Solution {
public boolean containsDuplicate(int[] nums) {
Arrays.sort(nums);
int n = nums.length;
for (int i = 0; i < n - 1; i++) {
if (nums[i] == nums[i + 1]) {
return true;
}
}
return false;
}
}
思路:将数组排序后,比较相邻两个数字的大小如果相同则说明有重复元素。