使用javascript做在线算法编程


Posted in Javascript onMay 25, 2018

基于node的readline一样可以使用标准流的输入输出

对于大学生在刚开始学习c ,c++, java的时候,写着hello word的代码,然后在命令框中输入输出;

基于很多算法的学习,在我短浅的认识中,身边的同学都是使用 c, c++,甚至是java去写;

很多算法题目中的输入描述和输出描述

例如牛客网上的算法题:

使用javascript做在线算法编程 

类似于这种的东西,在杭州acm的算法题目也是。

诀窍------使用nodejs内置封装好的readline模块;[kbd][/kbd]

1.readline 模块 【逐行读取】

readline主要的功能是提供了一个可以从可读流中读取数据;

这里可以对nodejs的可读流和可写流进行深入研究

2.如何使用readline?

一个基本的例子:

// 引入readline模块
const readline = require('readline');
//创建readline接口实例
const option ={
input:process.stdin,
output:process.stdout,
prompt:'>>'
}
const rl = readline.createInterface(option);
rl.question('你觉得js的这个模块怎么样?', (answer) => {
// 对答案进行处理
// 注意:log中的要使用 `` 而不是 '';
console.log(`你觉得:${answer}`);
// 关闭标准流
rl.close();
});

详情可以点击我的github的 readline_dome.js

3.进一步扩展去应用

3.1例如做一个简单的命令行界面;

// 来自官方例子实现的命令界面;
const readline = require('readline');
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
prompt: 'input> '
});
// rl.prompt() 方法会在 output 流中新的一行写入 readline.Interface 实例配置后的 prompt,用于为用户提供一个可供输入的新的位置。
rl.prompt();
// 'line'事件是 获取用户输入的值直到按下【return / enter】 按键;\n、\r 或 \r\n
rl.on('line', (line) => {
// ob.trim()==>从字符串中移除前导空格、尾随空格和行终止符。
switch (line.trim()) {
case 'hello':
console.log('world!');
break;
default:
console.log(`你输入的是:'${line.trim()}'`);
break;
}
rl.prompt();
}).on('close', () => {
console.log('再见!');
//推出标准流;
process.exit(0);
});

3.2类似于牛客网编程的例子;

这是一个单行读取的demo

const readline = require('readline');
const fs = require('fs')
// 单行读取;
const options={
input:process.stdin,
output:process.stdout
}
const rl = readline.createInterface(options);
// 单行读取;
rl.on('line',function(line){
line.trim();
console.log(`你输入的值(移除前导空格、尾随空格和行终止符):${line.trim()}`)
})

这是一个多行读取的demo

const readline = require('readline');
const fs = require('fs')
// 多行读取;
const options={
input:process.stdin,
output:process.stdout
}
const rl = readline.createInterface(options);
// 多行读取
// 多行处理的思路是:1.需要设定未开始读取的行数标志,并且如果开始读取的第一行是n行的行数;
//        2.需要通过判断是否已经到了设定的行数,若到了则只需在里面处理相关的算法逻辑;
var n = -1;
var sum = (a,b)=>a+b;
var arr =[];
rl.on('line',function(line){
// 表示已经在读取第一行的n行数;
if(n == -1){
// 类型转换和去除首位空格和终止符;并把行数赋值给n;
n = parseInt(line.trim());
console.log('n:'+n)
}
else{
// 存入数组;
arr.push(line.trim());
if(n == arr.length){
// 这里是执行你要的代码;
//  var result = arr[1];
var result = sum(arr[0],arr[1]);
console.log("result:"+result)
//恢复没读取状态;
arr.length=0;
n=-1;
}
}
})

总结

以上所述是小编给大家介绍的使用javascript做在线算法编程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
编写高性能的JavaScript 脚本的加载与执行
Apr 19 Javascript
Fastest way to build an HTML string(拼装html字符串的最快方法)
Aug 20 Javascript
js切换div css注意的细节
Dec 10 Javascript
jquery中 $.expr使用实例介绍
Jun 09 Javascript
基于Javascript实现返回顶部按钮
Feb 29 Javascript
Node.js connect ECONNREFUSED错误解决办法
Sep 15 Javascript
自制简易打赏功能的实例
Sep 02 Javascript
使用SVG基本操作API的实例讲解
Sep 14 Javascript
vue 之 .sync 修饰符示例详解
Apr 21 Javascript
微信小程序项目实践之验证码倒计时功能
Jul 18 Javascript
关于AOP在JS中的实现与应用详解
May 06 Javascript
JS实现点击下拉列表文本框中出现对应的网址,点击跳转按钮实现跳转
Nov 25 Javascript
JS实现的汉字与Unicode码相互转化功能分析
May 25 #Javascript
浅析node.js的模块加载机制
May 25 #Javascript
webpack4的迁移的使用方法
May 25 #Javascript
最后说说Vue2 SSR 的 Cookies 问题
May 25 #Javascript
详解webpack4多入口、多页面项目构建案例
May 25 #Javascript
js中的 || 与 && 运算符详解
May 24 #Javascript
vue axios整合使用全攻略
May 24 #Javascript
You might like
php反射应用示例
2014/02/25 PHP
Laravel框架模型的创建及模型对数据操作示例
2019/05/07 PHP
xml分页+ajax请求数据源+dom取结果实例代码
2008/10/31 Javascript
Javascript 生成指定范围数值随机数
2009/01/09 Javascript
jquery插件如何使用 jQuery操作Cookie插件使用介绍
2012/12/15 Javascript
防止登录页面出现在frame中js代码
2014/07/22 Javascript
JavaScript实现鼠标点击后层展开效果的方法
2015/05/13 Javascript
jquery彩色投票进度条简单实例演示
2020/07/23 Javascript
Bootstrap入门书籍之(五)导航条、分页导航
2016/02/17 Javascript
基于JavaScript实现智能右键菜单
2016/03/02 Javascript
js实现获取两个日期之间所有日期的方法
2016/06/17 Javascript
Javascript实现图片不间断滚动的代码
2016/06/22 Javascript
详解JS-- 浮点数运算处理
2016/11/28 Javascript
使用jquery给新生的th绑定hover事件的实例
2017/02/10 Javascript
微信小程序实现红包功能(后端PHP实现逻辑)
2018/07/11 Javascript
使用Three.js实现太阳系八大行星的自转公转示例代码
2019/04/09 Javascript
微信小程序第三方框架对比 之 wepy / mpvue / taro
2019/04/10 Javascript
js中位数不足自动补位扩展padLeft、padRight实现代码
2020/04/06 Javascript
js+css实现扇形导航效果
2020/08/18 Javascript
Vue通过阿里云oss的url连接直接下载文件并修改文件名的方法
2020/12/25 Vue.js
布同 统计英文单词的个数的python代码
2011/03/13 Python
在Python中操作列表之List.append()方法的使用
2015/05/20 Python
使用Python监控文件内容变化代码实例
2018/06/04 Python
结合OpenCV与TensorFlow进行人脸识别的实现
2019/10/10 Python
tensorflow tf.train.batch之数据批量读取方式
2020/01/20 Python
django 文件上传功能的相关实例代码(简单易懂)
2020/01/22 Python
python解决OpenCV在读取显示图片的时候闪退的问题
2021/02/23 Python
丝芙兰法国官网:SEPHORA法国
2016/09/01 全球购物
美国创意礼品网站:UncommonGoods
2017/02/03 全球购物
教师自我反思材料
2014/02/14 职场文书
企业文明单位申报材料
2014/05/16 职场文书
酒店七夕情人节活动策划方案
2014/08/24 职场文书
团队拓展活动总结
2014/08/27 职场文书
2014年公务员个人工作总结
2014/11/22 职场文书
导游词之西安大清真寺
2019/12/17 职场文书
如何在向量化NumPy数组上进行移动窗口
2021/05/18 Python