使用javascript做在線算法編程
基于node的readline一樣可以使用標(biāo)準(zhǔn)流的輸入輸出
對于大學(xué)生在剛開始學(xué)習(xí)c ,c++, java的時候,寫著hello word的代碼,然后在命令框中輸入輸出;
基于很多算法的學(xué)習(xí),在我短淺的認(rèn)識中,身邊的同學(xué)都是使用 c, c++,甚至是java去寫;
很多算法題目中的輸入描述和輸出描述
例如??途W(wǎng)上的算法題:
類似于這種的東西,在杭州acm的算法題目也是。
訣竅------使用nodejs內(nèi)置封裝好的readline模塊;[kbd][/kbd]
1.readline 模塊 【逐行讀取】
readline主要的功能是提供了一個可以從可讀流中讀取數(shù)據(jù);
這里可以對nodejs的可讀流和可寫流進(jìn)行深入研究
2.如何使用readline?
一個基本的例子:
// 引入readline模塊
const readline = require('readline');
//創(chuàng)建readline接口實例
const option ={
input:process.stdin,
output:process.stdout,
prompt:'>>'
}
const rl = readline.createInterface(option);
rl.question('你覺得js的這個模塊怎么樣?', (answer) => {
// 對答案進(jìn)行處理
// 注意:log中的要使用 `` 而不是 '';
console.log(`你覺得:${answer}`);
// 關(guān)閉標(biāo)準(zhǔn)流
rl.close();
});
詳情可以點擊我的github的 readline_dome.js
3.進(jìn)一步擴展去應(yīng)用
3.1例如做一個簡單的命令行界面;
// 來自官方例子實現(xiàn)的命令界面;
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()==>從字符串中移除前導(dǎo)空格、尾隨空格和行終止符。
switch (line.trim()) {
case 'hello':
console.log('world!');
break;
default:
console.log(`你輸入的是:'${line.trim()}'`);
break;
}
rl.prompt();
}).on('close', () => {
console.log('再見!');
//推出標(biāo)準(zhǔn)流;
process.exit(0);
});
3.2類似于??途W(wǎng)編程的例子;
這是一個單行讀取的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(`你輸入的值(移除前導(dǎo)空格、尾隨空格和行終止符):${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.需要設(shè)定未開始讀取的行數(shù)標(biāo)志,并且如果開始讀取的第一行是n行的行數(shù);
// 2.需要通過判斷是否已經(jīng)到了設(shè)定的行數(shù),若到了則只需在里面處理相關(guān)的算法邏輯;
var n = -1;
var sum = (a,b)=>a+b;
var arr =[];
rl.on('line',function(line){
// 表示已經(jīng)在讀取第一行的n行數(shù);
if(n == -1){
// 類型轉(zhuǎn)換和去除首位空格和終止符;并把行數(shù)賦值給n;
n = parseInt(line.trim());
console.log('n:'+n)
}
else{
// 存入數(shù)組;
arr.push(line.trim());
if(n == arr.length){
// 這里是執(zhí)行你要的代碼;
// var result = arr[1];
var result = sum(arr[0],arr[1]);
console.log("result:"+result)
//恢復(fù)沒讀取狀態(tài);
arr.length=0;
n=-1;
}
}
})
總結(jié)
以上所述是小編給大家介紹的使用javascript做在線算法編程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
JS獲取select-option-text_value的方法
這篇文章主要介紹了JS獲取select-option-text_value的方法,有需要的朋友可以參考一下2013-12-12
js getBoundingClientRect() 來獲取頁面元素的位置
該方法已經(jīng)不再是IE Only了,F(xiàn)F3.0+和Opera9.5+已經(jīng)支持了該方法,可以說在獲得頁面元素位置上效率能有很大的提高,在以前版本的Opera和Firefox中必須通過循環(huán)來獲得元素在頁面中的絕對位置。2010-11-11
微信小程序?qū)崿F(xiàn)虎年春節(jié)頭像制作
春節(jié)來臨之際,看到有網(wǎng)友分享了網(wǎng)頁版的虎年頭像制作工具。本文將為大家介紹一個虎年春節(jié)頭像制作小程序,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-02-02

