牛客编译模式选择node编译器
目录
单行输入:
const readline = require('readline');
const r1 = readline.createInterface({
input:process.stdin,
output:process.stdout
})
r1.on('line',function(line){
console.log(line.split('').reverse().join(''))
})
多行输入:(行数已知)
/*
【多行输入】
line事件是每次换行时都会触发(前提是没有close),
如果在已知行数的情况下,可以将输入push到临时数组中,直到一组数据全部push完成之后再对该数组做处理,到下一组时将该数组清空。
*/
const readline = require('readline');
let r1 = readline.createInterface({
input:process.stdin,
output:process.stdout
})
//输入2个长度相等的字符串
const Num = 2
let inputs = []
r1.on('line',function(input){
inputs.push(input.trim())
// 满足一组行数条件之后再进行数据的处理
if(Num == inputs.length) {
let res = []
let s1 = inputs[0].split('')
let s2 = inputs[1].split('')
let len = s1.length
for (let i = 0; i < len; i++) {
res.push(s1[i])
res.push(s2[len - i - 1])
}
res = res.join('')
console.log(res)
inputs.length = 0
}
})
多行输入:(行数未知)
/*
输入行数不确定
这种类型题目大多是第一个输入为数据的组数,然后会输入这几组数据,即为1+n模式。
所以每组数据的第一个一定是接下来要获取输入的行数,后面这部分相当于已知行数,只需要在上面的基础上添加获取行数逻辑即可。
*/
const readline = require('readline');
const r1 = readline.createInterface({
input:process.stdin,
output:process.stdout
});
let Num = 0;
let inputs = []
r1.on('line',function(input){
if(Num == 0){
Num = parseInt(input.trim());
} else{
inputs.push(input.trim());
if(Num == inputs.length) {
let res
inputs.sort((a, b) => a - b)
if(Num % 2 !== 0) {
res = inputs[(Num - 1) / 2]
} else {
// 这里要注意转化一下 不然会拼接成字符串
res = Math.floor((parseInt(inputs[Num / 2]) + parseInt(inputs[Num / 2 - 1])) / 2)
}
console.log(res)
// 不要忘记清空
inputs.length = 0
Num = 0
}
}
})
文章参考于:这里