美文网首页
前端刷华为机考17-18题

前端刷华为机考17-18题

作者: 小遁哥 | 来源:发表于2023-09-06 18:28 被阅读0次

HJ17 坐标移动

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 x = 0,y = 0;
        line.split(";").filter(Boolean).forEach(pos=>{
            [...pos.matchAll(/^([A-Z])(\d+)$/g)].forEach(list=>{
                if(list[1] == 'A'){
                    x -= +list[2]
                }
                else if(list[1] == 'D'){
                    x += +list[2]
                }
                else if(list[1] == 'W'){
                    y += +list[2]
                }
                else{
                    y -= +list[2]

                }
            });
        })

        console.log(x+','+y)
    }
}()

HJ18 识别有效的 IP 地址和掩码并进行分类统计

const readline = require("readline");

const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout,
});
let infos = {
    a: 0,
    b: 0,
    c: 0,
    d: 0,
    e: 0,
    error: 0,

    private: 0,
};
rl.on("line", function (line) {
    const [ipList, codeList] = line
        .split("~")
        .map((item) => item.split(".").filter(Boolean).map(item=>+item));


    let isError = false;

    if (ipList[0] == 0 || ipList[0] == 127) {
        return;
    }

    if (ipList.length != 4 || ipList.some((item) => item > 255 || item < 0)) {
        infos.error++;
        isError = true;
    } else if (
        codeList.length != 4 ||
        codeList.reduce((pre,cur)=>pre + cur.toString(2).padStart(8,'0'),"").match(/^1+0+$/) == null
    ) {
        infos.error++ ;
        isError = true;
    }




    if (!isError) {

            if (ipList[0] >= 1 && ipList[0] <= 126) {

                infos.a++;
            }
            if (ipList[0] >= 128 && ipList[0] <= 191) {
                infos.b++;
            }
            if (ipList[0] >= 192 && ipList[0] <= 223) {
                infos.c++;
            }
            if (ipList[0] >= 224 && ipList[0] <= 239) {
                infos.d++;
            }
            if (ipList[0] >= 240 && ipList[0] <= 255) {
                infos.e++;
            }


        if (
            ipList[0] == 10 ||
            (ipList[0] == 172 && ipList[1] >= 16 && ipList[1] <= 31) ||
            (ipList[0] == 192 && ipList[1] == 168)
        ) {
            infos.private++;
        }
    }
});
rl.on("close", () => {
    console.log(
        Object.values(infos)
            .join(" ")
    );
});

ip 第一部分是 0 或者 127 时不管错不错,直接忽略

当 ip 地址与掩码都存在错误时,只算一次

验证掩码是否合法255.0.1.0

255 的二进制是 11111111,总共 8 位,如果不足 8 位则要在前面补 0

0 的二进制 00000000

1 的二进制 00000001

合起来 11111111000000000000000100000000,不符合 1 的后面全是 0 的规则,除了用/^(1+)(0+)$/外,还可以通过lastIndexOf判断 1 是否在 0 前面

离职在家的 190 天

相关文章

  • 前端刷题网站

    想要提升自己能力的同学并同时拿到一个满意的offer,刷题当然是提升知识面的必备的一部分,所以今天给大家推荐两个干...

  • 前端刷题网站

    leetcode(力扣) 算法刷题 英文网址 https://leetcode.com/[https://le...

  • IOS面试 (华为) --- 算法编辑器介绍

    华为面试相比其他大厂有点区别, 第一轮是机考算法题, 算法过了才可以继续面试。算法面板用的是牛客网的算法编辑器( ...

  • 八年级的学生雅思考了6.5分做对了什么?

    7月13号,小章同学去北京考了雅思。 yq影响,这次考试是机考。 考试前刷了三天题,阅读做的不好,小章同学心里没底...

  • 前端刷题(不停更新记录)

    1、css兼容性有哪几种处理方案?- 1、css初始化 margin:0;padding:0 2、各自浏览器适应 ...

  • 刷题刷题

    时间紧迫,任务繁重,又有疫情影响,搞的人心惶惶,一时间复习得不安宁,又舍不得摆烂。 在焦灼、惶恐的情绪中,紧张急迫...

  • 2018法考改革将实行2+1考试模式

    法考改革除了报名条件、从业资格范围等方面的变化外,考试形式可以说是变化较大的一个方面:客观题全面机考,主观题试机考...

  • 遇到的问题

    还需要学习的东西vue源码nodejshttp等网络知识typescript设计模式 还需要刷的题牛客网前端50题...

  • map、parseInt

    在牛客刷题的时候,遇到YY前端的一道题,有点意思,写下来分享 [“1", "2", "3"].map(parseI...

  • 2022-09-16

    刷题,刷题还是刷题

网友评论

      本文标题:前端刷华为机考17-18题

      本文链接:https://www.haomeiwen.com/subject/rszkvdtx.html