-
-
Notifications
You must be signed in to change notification settings - Fork 155
/
Copy pathcontainsDuplicate.js
66 lines (61 loc) · 1.82 KB
/
containsDuplicate.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
// Early exit using set:- TC: O(n), SC: O(n)
function containsDuplicate(nums) {
let noDupsSet = new Set();
for(const num of nums) {
if(noDupsSet.has(num)) {
return true;
}
noDupsSet.add(num);
}
return false;
}
// Early exit using object:- TC: O(n), SC: O(n)
function containsDuplicateUsingObject(nums) {
let noDupsObj = {};
for(const num of nums) {
if(noDupsObj[num]) {
return true;
}
noDupsObj[num] = true;
}
return false;
}
//Use Set size:- TC: O(n), SC: O(n)
function containsDuplicateUsingSize(nums) {
return new Set(nums).size !== nums.length;
}
//Using sort and iteration:- TC: O(n log n), SC: O(n)
function containsDuplicateUsingSort(nums) {
nums.sort((a, b) => a-b);
for(let i =1; i< nums.length; i++) {
if(nums[i] === nums[i-1]) {
return true;
}
}
return false;
}
//Using naive/Brute force:- TC: O(n^2), SC: O(1)
function containsDuplicateUsingBruteforce(nums) {
for(let i =0; i< nums.length-1; i++) {
for (let j = i+1; j < nums.length; j++) {
if(nums[i] == nums[j]) {
return true;
}
}
}
return false;
}
console.log("-----Has duplicates----");
let nums1 = [8, 6, 4, 2, 6];
console.log(containsDuplicate(nums1));
console.log(containsDuplicateUsingObject(nums1));
console.log(containsDuplicateUsingSize(nums1));
console.log(containsDuplicateUsingSort(nums1));
console.log(containsDuplicateUsingBruteforce(nums1));
console.log("-----No duplicates----");
let nums2 = [1, 3, 5, 7, 9];
console.log(containsDuplicate(nums2));
console.log(containsDuplicateUsingObject(nums2));
console.log(containsDuplicateUsingSize(nums2));
console.log(containsDuplicateUsingSort(nums2));
console.log(containsDuplicateUsingBruteforce(nums2));