-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcountDuplicates.js
70 lines (53 loc) · 2.46 KB
/
countDuplicates.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
67
68
69
70
// Counting Duplicates from http://www.codewars.com/kata/54bf1c2cd5b56cc47f0007a1/train/javascript
/*
Count the number of Duplicates
Write a function that will return the count of distinct case-insensitive alphabetic characters and numeric digits that occur more than once in the input string. The input string can be assumed to contain only alphabets (both uppercase and lowercase) and numeric digits.
Example
"abcde" -> 0 # no characters repeats more than once
"aabbcde" -> 2 # 'a' and 'b'
"aabBcde" -> 2 # 'a' occurs twice and 'b' twice (bandB)
"indivisibility" -> 1 # 'i' occurs six times
"Indivisibilities" -> 2 # 'i' occurs seven times and 's' occurs twice
"aA11" -> 2 # 'a' and '1'
"ABBA" -> 2 # 'A' and 'B' each occur twice
*//*eslint-disable*/
/**
finds the count of duplicates in a string
@param {string} text - input string with or without duplicates
@returns {number} count of duplicates
*/
// const duplicateCount = text => (counts = [...text.toLowerCase()].reduce((counts, char) => counts[char] ? (counts[char]++, counts) : (counts[char] = 1, counts), {}), Object.values(counts).filter(count => count > 1).length);
duplicateCount=t=>(c=[...t.toLowerCase()].reduce((c,v)=>c[v]?(c[v]++,c):(c[v]=1,c),{}),Object.values(c).filter(c=>c>1).length)
duplicateCount=t=>[...t.toLowerCase()].filter((c,i,t)=>t.indexOf(c)!=i&i==t.lastIndexOf(c)).length
duplicateCount=t=>new Set([...t.toLowerCase()].filter((c,i,l)=>l.slice(i+1).includes(c))).size
duplicateCount=t=>new Set([...t.toLowerCase()].sort().join``.match(/(.)\1/g)).size
duplicateCount=t=>([...t.toLowerCase()].sort().join``.match(/(.)\1+/g)||'').length
duplicateCount=t=>new Set(t.toLowerCase().match(/(.)(?=.*\1)/g)).size
const {expect} = require('chai');
describe('duplicateCount function', () => {
const tests = {
a: 0,
abcde: 0,
aabbcde: 2,
aabBcde: 2,
Indivisibility: 1,
Indivisibilities: 2,
abcdefghijklmnopqrstuvwxyz: 0,
abcdefghijklmnopqrstuvwxyzbaaAAB: 2,
abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz: 26,
abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ: 26,
abcdefghwxyz: 0,
abcdefghABCDABCABA: 4,
abcdefghijABCDEABCDABCABa: 5,
abcdefghijklABCDEFabcdeABCDABCaba: 6,
abcdefghijABCDEabcdabcabA: 5,
abcdefghijklabcdefabcdeabcdABCABA: 6,
abcdefABCabA: 3,
zZzZzZzZzZz: 1
};
Object.entries(tests).forEach(([test, sol]) => {
it(`should return ${sol} given ${test}`, () => {
expect(duplicateCount(test)).to.equal(sol);
});
});
});