mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-05 16:26:47 +08:00

* feat: improved memoize function used Map instead of object & used the JSON.stringfy method for generate a valid string as a key * docs: modified documentation * style: format with standard * docs: modified stringify doc * refactor: remove two repetition implementation * feat: added validation, test codes * chore: remove useless words * feat: added types for jest * chore: added link box * feat: added new validation test casses & methods * style: formated with standard * feat: added parse method & test cases * docs: added js docs * chore: added default import export * feat: imporved algorithm via replace method * test: added two test cases * feat: added jest type for suggestions * feat: added `reduceRight` & `trim` method * chore: added helper variable * feat: added new rotation option * Revert "chore: added helper variable" This reverts commit 489544da0a3d479910fbea020d3be3d0d10681bf. * remove: yarn lock * chore: fix grammer * feat: remove revert * chore: added new line
25 lines
1.1 KiB
JavaScript
25 lines
1.1 KiB
JavaScript
/**
|
||
* @function ROT13
|
||
* @description - ROT13 ("rotate by 13 places", sometimes hyphenated ROT-13) is a simple letter substitution cipher that replaces a letter with the 13th letter after it in the alphabet. ROT13 is a special case of the Caesar cipher which was developed in ancient Rome. Because there are 26 letters (2×13) in the basic Latin alphabet, ROT13 is its own inverse; that is, to undo ROT13, the same algorithm is applied, so the same action can be used for encoding and decoding. The algorithm provides virtually no cryptographic security, and is often cited as a canonical example of weak encryption.
|
||
* @see - [wiki](https://en.wikipedia.org/wiki/ROT13)
|
||
* @param {String} str - string to be decrypted
|
||
* @return {String} decrypted string
|
||
*/
|
||
function ROT13 (str) {
|
||
if (typeof str !== 'string') {
|
||
throw new TypeError('Argument should be string')
|
||
}
|
||
|
||
return str.replace(/[a-z]/gi, (char) => {
|
||
const charCode = char.charCodeAt()
|
||
|
||
if (/[n-z]/i.test(char)) {
|
||
return String.fromCharCode(charCode - 13)
|
||
}
|
||
|
||
return String.fromCharCode(charCode + 13)
|
||
})
|
||
}
|
||
|
||
export default ROT13
|