前端笔试中oj算法题的解法模版

如今计算机行业的校招大多都是需要先进行笔试,之后才有面试,如果发现题目都会但是却因为自己不了解接受输入参数的模板导致没能通过笔试,哪还是比较可惜的(我就碰到过这种问题pwq)。因此我特意上网查了一下,并结合多个网站进行测试,最终找到了一个相对通用的模板。本篇文章就以一行输入两个数字a,b;输出a和b之和这道题目来写的模板。

oj算法输入使用的是readline,但是不同网站上有不同的写法。我这里知道的有两种:

方法一:

写法一:
javascript 复制代码
const readline = require('readline');
const rl = readline.createInterface({ input: process.stdin });
rl.on('line', (input) => {
    if (input === '') {
        return rl.close();
    }
    const [a, b] = input.split(' ').map(Number)
    console.log(a + b);
});

方法一的第一种写法适合处理多行输入,单行处理。比如:输入3行,每行两个数,输出每行两个 数的和。

写法二:
javascript 复制代码
const readline = require('readline');
const rl = readline.createInterface({ input: process.stdin });
const arr=[]//创建数组准备接受输入
rl.on('line', (input) => {
    if (input === '') {
        return rl.close();
    }
    arr = input.split(' ').map(Number)//将输入的单行数据转成数字数组赋值给arr。因为本片文章以输入单行两个数字为例子,所以这么写,实际问题需要发生相应比变化
});

rl.on('close', () => {//所有需要数据接收完成后,在次方法中进行处理。
  console.log(arr[0]+arr[1])
});

第二种写法适合多行输入,整体处理。比如: 输入三行,每行一个数,输出这是三个数的和。

方法二;

写法一:
javascript 复制代码
const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;

void async function () {
    while(line = await readline()){
        let tokens = line.split(' ');
        let a = parseInt(tokens[0]);
        let b = parseInt(tokens[1]);
        console.log(a + b);
    }
}()

此种写法对应方法一中的写法,适合处理多行输入,单行处理。

相应的,方法二也有对应的多行输入,整体处理的写法

写法二:
javascript 复制代码
const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;

void async function () {
    let arr=[]
    while(line = await readline()){
        arr.push(line)
    }
    console.log(arr[0]+arr[1])
}()

上面总共提到两种方法,根据不同的输出有不同的写法。大家可以按照自己的理解选择一种进行记忆,推荐使用方法一,因为一开始将方法二放在方法一的页面中报错了,后来才好了,不知道是什么原因......

希望本篇文章可以帮助到没接触过oj算法的同学,祝大家能够拿到心仪的offer!!!

相关推荐
mCell3 小时前
使用 useSearchParams 同步 URL 和查询参数
前端·javascript·react.js
mCell4 小时前
前端路由详解:Hash vs History
前端·javascript·vue-router
海上彼尚4 小时前
无需绑卡的海外地图
前端·javascript·vue.js·node.js
1024肥宅4 小时前
手写 call、apply、bind 的实现
前端·javascript·ecmascript 6
科杰智能制造5 小时前
纯前端html、js实现人脸检测和表情检测,可直接在浏览器使用
前端·javascript·html
每天吃饭的羊5 小时前
组件库的有些点击事件是name-click这是如何分装de
前端·javascript·vue.js
x***01066 小时前
SpringSecurity+jwt实现权限认证功能
android·前端·后端
1024肥宅6 小时前
防抖(Debounce)
前端·javascript·ecmascript 6
1024肥宅6 小时前
节流(Throttle)
前端·javascript·ecmascript 6
by__csdn6 小时前
Vue2纯前端图形验证码实现详解+源码
前端·javascript·typescript·vue·状态模式·css3·canva可画