在 JavaScript 中根据字符频率对字符串进行编码

javascriptweb developmentfront end technology

问题

我们需要编写一个 JavaScript 函数,该函数将字符串 str 作为第一个也是唯一的参数。

我们的函数应该根据输入字符串创建一个新字符串,其中新字符串中的每个字符如果在原始字符串中仅出现一次则为 '(',如果在原始字符串中出现多次则为 ')'。

我们应该忽略大写字母

例如,如果函数的输入是 −

输入

const str = 'Success';

输出

const output = ')())())';

示例

以下是代码 −

const str = 'Success';
const mapString = (str = '') => {
   const mainStr = str.toLowerCase()
   const hash = {}
   let res = ''
   for (let char of mainStr) {
      hash[char] = ~~hash[char] + 1
   }
   for (let char of mainStr) {
      if (hash[char] > 1) {
      res += ')'
   } else {
      res += '('
   }
}
   return res
};
console.log(mapString(str));

输出

)())())

相关文章