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

相关推荐
万少10 分钟前
HarmonyOS 开发必会 5 种 Builder 详解
前端·harmonyos
橙序员小站2 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名5 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫5 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊5 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter5 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折5 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_6 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
Angelial6 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
jiayu6 小时前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端