You can find all the code in this post at repo Github.
String related challenges
Is alphanumeric
/**
* @param {any} char
* @return {Boolean}
*/
function isAlphaNumeric(char) {
return /[A-Za-z0-9]/.test(char);
}
// Usage example
console.log(isAlphaNumeric("a")); // => true
console.log(isAlphaNumeric(0)); // => true
console.log(isAlphaNumeric("!")); // => false
Camel case <-> Snake case
// camel case to snake case
/**
* @param {string} str
* @return {string}
*/
function toKebabCase(str) {
let temp = str.replace(/[A-Z]/g, function (i) {
return "_" + i.toLowerCase();
});
if (temp[0] === "_") {
temp = temp.slice(1);
}
return temp;
}
// Usage example
console.log(toKebabCase("testMethod")); // => "test_method"
// snake case to camel case
/**
* @param {string} str
* @return {string}
*/
function toCamelCase(str) {
return str.replace(
/([a-z])_([a-z])/gi,
(_, left, right) => left + right.toUpperCase()
);
}
// Usage example
console.log(toCamelCase("test_method")); // => "testMethod"
Compare version numbers
/**
* @param {string} version1
* @param {string} version2
* @return {number}
*/
function compareVersion(version1, version2) {
const v1Arr = version1.split(".");
const v2Arr = version2.split(".");
for (let i = 0; i < Math.max(v1Arr.length, v2Arr.length); i++) {
const v1Num = Number(v1Arr[i] ?? 0);
const v2Num = Number(v2Arr[i] ?? 0);
if (v1Num > v2Num) {
return 1;
} else if (v1Num < v2Num) {
return -1;
}
}
return 0;
}
// Usage example
console.log(compareVersion("12.1.0", "12.0.9")); // => 1, meaning first one is greater
console.log(compareVersion("12.1.0", "12.1.2")); // => -1, meaning latter one is greater
console.log(compareVersion("5.0.1", "5.0.1")); // => 0, meaning they are equal.
Version numbers sorting
/**
* @param {string[]} versions
* @return {string[]}
*/
function sortVersions(versions) {
return versions.sort((a, b) => {
const aParts = a.split(".").map(Number);
const bParts = b.split(".").map(Number);
for (let i = 0; i < Math.max(aParts.length, bParts.length); i += 1) {
const aPart = aParts[i] ?? 0;
const bPart = bParts[i] ?? 0;
if (aPart !== bPart) {
return aPart - bPart;
}
}
return 0;
});
}
// Usage example
const sortedVersions = sortVersions([
"0.1.1",
"2.3.3",
"0.302.1",
"4.2",
"4.3.5",
"4.3.4.5",
]);
console.log(sortedVersions); // => [ '0.1.1', '0.302.1', '2.3.3', '4.2', '4.3.4.5', '4.3.5' ]
Compress a string
/**
* @param {string} str
* @return {string}
*/
function compress(str) {
if (!str) {
return "";
}
let compressed = "";
let count = 1;
for (let i = 1; i <= str.length; i += 1) {
if (i < str.length && str[i] === str[i - 1]) {
count += 1;
} else {
compressed += str[i - 1];
if (count > 1) {
compressed += count;
}
count = 1;
}
}
return compressed;
}
// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
Uncompress a string
/**
* @param {string} str
* @returns {string}
*/
function uncompress(str) {
const stack = [];
let currentNum = 0;
let currentStr = "";
for (const char of str) {
if (char >= "0" && char <= "9") {
currentNum = currentNum * 10 + Number(char);
} else if (char === "(") {
stack.push([currentStr, currentNum]);
currentStr = "";
currentNum = 0;
} else if (char === ")") {
const [prevStr, num] = stack.pop();
currentStr = prevStr + currentStr.repeat(num);
} else {
currentStr += char;
}
}
return currentStr;
}
// Usage example
console.log(uncompress("3(ab)")); // => 'ababab'
console.log(uncompress("3(ab2(c))")); // => 'abccabccabcc'
Find the length of the longest word in a string
/**
* @param {string} str
* @return {number}
*/
function longestLength(str) {
const strArr = str.split(" ");
let length = 0;
for (let i = 0; i < strArr.length; i++) {
if (strArr[i].length > length) {
length = strArr[i].length;
}
}
return length;
}
// Usage example
console.log(longestLength("The longest word is thelongestword")); // => 14
Find the word with longest length in a string
/**
* @param {string} str
* @return {string[]}
*/
function longestWord(str) {
const strArr = str.split(" ");
const result = [];
let max = 0;
for (const char of strArr) {
if (char.length > max) {
max = char.length;
}
}
for (const char of strArr) {
if (char.length === max) {
result.push(char);
}
}
return result.join("");
}
// Usage example
console.log(longestWord("The longest word is thelongestword")); // => "thelongestword"
Most frequently occurring character
/**
* @param {string} str
* @returns {string | string[]}
*/
function count(str) {
const map = new Map();
const result = [];
for (const char of str) {
map.set(char, (map.get(char) ?? 0) + 1);
}
const max = Math.max(...map.values());
for (const [key, value] of map) {
if (value === max) {
result.push(key);
}
}
return result.length === 1 ? result[0] : result;
}
// Usage example
console.log(count("abbccc")); // => 'c'
console.log(count("abbcccddd")); // => ['c', 'd'];
Get string length(support emojis)
/**
* @param {String} str
* @return {Number}
*/
function getStringLength(str) {
return Array.from(new Intl.Segmenter().segment(str)).length;
}
// Usage example
console.log(getStringLength("test๐")); // => 5
console.log("test๐".length); // => 6
Reference
- Alphanumericals - Wikipedia.org
- Naming convention (programming) - Wikipedia.org
- 79. convert snake_case to camelCase - BFE.dev
- Software versioning - Wikipedia.org
- 157. semver compare - BFE.dev
- 165. Compare Version Numbers - LeetCode
- 97. compress a string - BFE.dev
- 173. uncompress string - BFE.dev
- 145. most frequently occurring character -BFE.dev
Top comments (0)