题解 | #删除字符串中出现次数最少的字符#

删除字符串中出现次数最少的字符

https://www.nowcoder.com/practice/05182d328eb848dda7fdd5e029a56da9

const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;

void async function () {
    // Write your code here
    while(line = await readline()){
        // 统计字符串出现次数
        let codeDic = {};
        for(let i = 0; i < line.length; i++) {
            if(codeDic[line[i]]) {
                codeDic[line[i]]++;
            } else {
                codeDic[line[i]] = 1;
            }
        }
        // 找到需要删除的字符串,存入 deleteCodes
        let arrVal = Object.values(codeDic);
        let arrKey = Object.keys(codeDic);
        let deleteCodes = new Set([arrKey[0]]),minVal = arrVal[0];

        for(let i = 1; i < arrVal.length; i++) {
            if(minVal > arrVal[i]) {
                minVal = arrVal[i];
                deleteCodes = new Set([arrKey[i]]);
            } else if(minVal == arrVal[i]) {
                deleteCodes.add(arrKey[i]);
            }
        }

        //删除需要的字符串
        let res = [];
        for(let i = 0; i < line.length; i++) {
            if(!deleteCodes.has(line[i])) {
                res.push(line[i]);
            }
        }
        console.log(res.join(''));

    }
}()

全部评论

相关推荐

吴offer选手:下午mt一来就告警说项目来不及,估计明天拿了权限就要参与开发了 已老实
实习生的蛐蛐区
点赞 评论 收藏
分享
头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务