使用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接口實(shí)例 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(); });
詳情可以點(diǎn)擊我的github的 readline_dome.js
3.進(jìn)一步擴(kuò)展去應(yīng)用
3.1例如做一個簡單的命令行界面;
// 來自官方例子實(shí)現(xiàn)的命令界面; const readline = require('readline'); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, prompt: 'input> ' }); // rl.prompt() 方法會在 output 流中新的一行寫入 readline.Interface 實(shí)例配置后的 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-12js 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