前端笔试中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!!!

相关推荐
喝拿铁写前端15 分钟前
一套面向 Web、H5、小程序与 Flutter 的多端一致性技术方案
前端·架构
yaaakaaang21 分钟前
(一)前端,如此简单!---下载Nginx
前端·nginx
牛奶26 分钟前
为什么全国人民都能秒开同一个视频?
前端·http·cdn
KongHen021 小时前
uniapp-x实现自定义tabbar
前端·javascript·uni-app·unix
汪子熙1 小时前
TS2320 错误的本质、触发场景与在 Angular / RxJS 项目中的系统化应对
前端·javascript·angular.js
我命由我123451 小时前
React - BrowserRouter 与 HashRouter、push 模式与 replace 模式、编程式导航、withRouter
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
Younglina1 小时前
用AI全自动生成连环画?我试了,效果惊艳!
前端·ai编程·claude
Devin_chen1 小时前
ES6 Class 渐进式详解
前端·javascript
小番茄夫斯基1 小时前
前端开发的过程中,需要mock 数据,但是走的原来的接口,要怎么做
前端·javascript
peachSoda72 小时前
前端想转AI全栈-初步练习记录
前端·人工智能