【华为机试真题JavaScript】字符串分割

目录

题目描述

输入描述

输出描述

参考示例

参考代码

机试介绍

写在最后


题目描述

给定一个非空字符串S,其被N个‘-’分隔成N+1的子串,给定正整数K,要求除第一个子串外,其余的子串每K个字符组成新的子串,并用‘-’分隔。对于新组成的每一个子串,如果它含有的小写字母比大写字母多,则将这个子串的所有大写字母转换为小写字母;反之,如果它含有的大写字母比小写字母多,则将这个子串的所有小写字母转换为大写字母;大小写字母的数量相等时,不做转换。


输入描述

输入为两行,第一行为参数K,第二行为字符串S。

输出描述

输出转换后的字符串。


参考示例

示例1

输入
3
12abc-abCABc-4aB@


输出
12abc-abc-ABC-4aB-@


说明
子串为12abc、abCABc、4aB@,第一个子串保留,后面的子串每3个字符一组为abC、ABc、4aB、@,abC中小写字母较多,转换为abc,ABc中大写字母较多,转换为ABC,4aB中大小写字母都为1个,不做转换,@中没有字母,连起来即12abc-abc-ABC-4aB-@


示例2

输入
12
12abc-abCABc-4aB@


输出
12abc-abCABc4aB@


说明
子串为12abc、abCABc、4aB@,第一个子串保留,后面的子串每12个字符一组为abCABc4aB@,这个子串中大小写字母都为4个,不做转换,连起来即12abc-abCABc4aB@

参考代码

let strFun =  function(k, s) {
    let numk = parseInt(k);
    let str = s;
    // 1.除第一个子串外,其他的先拼在一起
    const arr=  str.split('-');
    // 第一个子串startStr
    const startStr = arr[0];
    // console.log(startStr);

    // 除第一个子串外,其余子字符串lastStr
    const arr1 = arr.slice(1, arr.length);
    const lastStr = arr1.join('')
    // console.log(lastStr);

    // 2.其余子字符串lastStr,按照每k个用'-'分隔开,这时候结果为resLastStr
    let resLastStr = "";
    for (let i = 0; i < lastStr.length; i++) {
        if(i % numk === 0 && i != 0) resLastStr += '-';
        resLastStr += lastStr[i];
    }
    // console.log(resLastStr);

    // 3.遍历resLastStr.split('-')的数组,每一项大小写计数、比较、转换
    let countA = 0; // 大写字母数量
    let counta = 0; // 小写字母数量
    const regA = /[A-Z]/; // 正则匹配大写字母
    const rega = /[a-z]/; // 正则匹配小写字母
    let resLastStrArr =  resLastStr.split('-'); // 其余子字符串lastStr用'-'分隔组成的数组
    for (let j = 0; j < resLastStrArr.length; j++) {
        for (let i = 0; i < resLastStrArr[j].length; i++) {
            if (regA.test(resLastStrArr[j][i])) countA++;
            if (rega.test(resLastStrArr[j][i])) counta++
        }
        if (countA > counta) {
            resLastStrArr[j]= resLastStrArr[j].toUpperCase();
            // console.log(resLastStrArr[j].toUpperCase());
        } else if ( countA < counta) {
            resLastStrArr[j]= resLastStrArr[j].toLowerCase();
            // console.log(resLastStrArr[j].toLowerCase()); 
        } 
        // 每计数完一个字符串,归零一次
        countA = 0;
        counta = 0;
    }

    // 4.把原来的头部字符串加上来,数组转回'-'分割的字符串
    resLastStrArr.unshift(startStr);
    const res = resLastStrArr.join('-');
    console.log(res);
}

strFun(3, '12abc-abCABc-4aB@')

机试介绍


三道中等难度题目,总分400分,前两道均为100分,后一道为200分,每道题的时间限制为1S(常规算法解答不出,可以用暴力方法)
机考分数是按照题目用例的通过数量的比例算分数 (若最后一道题做不出来,可将边界情况结果等写出来 )
机考时长2个半小时,若以冲刺机考最高分为目的,则做题时间分配前两道题40分钟,最后一题70分钟(平时练习可以按照40分钟的时限)
机考分数线根据招聘目标院校和非目标院校有不同(不同 华为招聘部门会有差异)

写在最后

创作不易!

如果觉得内容对你有帮助,麻烦给个三连关注支持一下我!

如果有错误,请在评论区指出,我会及时更改!


感谢各位的阅读,文章掺杂个人理解,如有错误请联系我指出~

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

forest_long

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值