摘要:用寫編程題的核心在的接口,讀取輸入行,模塊提供了一個接口,用于從可讀流如讀取數據,每次讀取一行。五總結通過以上這種方式,應該能完成大部分的在線編程題,有需要的童鞋可以試試看。
一.js的控制臺輸入
做各大公司的在線編程題,一般都有輸入輸出,傳統的js不能完成讀取輸入的功能,這時候為了繼續用js寫編程題,只能借助node.js來進行在線筆試的輸入輸出,下面具體來說說這個問題。
用node.js寫編程題的核心在node的readline接口,讀取輸入行,
require("readline") 模塊提供了一個接口,用于從可讀流(如 process.stdin)讀取數據,每次讀取一行。 它可以通過以下方式使用:
const readline = require("readline");
基本用法如下:
const readline = require("readline");//在這里引入 const rl = readline.createInterface({ //創建輸入輸出接口 input: process.stdin, output: process.stdout }); rl.on("line",function(line){//監聽控制臺的輸入 var data=line.trim();//拿到控制臺輸入 var result=....//編程邏輯處理 console.log(result); //輸出結果 });
通過這樣一個過程,拿到輸入->邏輯處理->輸出結果,完成在線筆試。
但是實際中會碰到一個棘手的問題,就是有的題目,輸入不止一行,會有2行甚至N行的輸入,那么像上面這種寫法,data只能拿到第一次單行的輸入,不能夠拿到多行輸入,所以不能解決問題,那么接下來通過兩個簡單小例子介紹如何進行接收控制臺多行輸入。
二.兩行輸入的在線編程
題目:輸入兩行,第一行是字符串s1,第二行是字符串s2,輸出兩個字符串連接后的結果。
例子:
輸入 "hello" "world" 輸出 "helloworld"
代碼如下:
const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout }); var k=2;//這里代表題目中設定好的輸入的行數 var rows=[]; //用于存儲每行的輸入 rl.on("line",function(line){ rows.push(line);//將每次輸入的行數據存入 if(k==rows.length){//當輸入的行數等于設定的k值時,開始邏輯處理 var result=rows[0]+rows[1]; //連接字符串 console.log(result); //輸出結果 rows.length=0;//狀態重置 } });
三.N行輸入的在線編程
題目:輸入數字N(1
輸入:4 "nice" "to" "meet" "you" 輸出:"nicetomeetyou"
代碼如下:
const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout }); var k=-1;//先給行數置-1,表示還沒開始讀取 var rows=[]; //用于存儲每行的輸入 rl.on("line",function(line){ if(k<0){ k=parseInt(line.trim());//讀取第一行,得到接下來輸入的行數 }else{ rows.push(line.trim());//將每次輸入的行數據存入 if(k==rows.length){//當輸入的行數等于設定的k值時,開始邏輯處理 var result=rows.reduce(function(fir,cur){ //連接字符串 return fir+cur; }); console.log(result); //輸出結果 rows.length=0;//狀態重置 k=-1; } } });
四.通用性的方式:按照數據流輸入的方式
在做筆試時碰到過例題的輸入方式,不是按行讀入的,是一次性讀入,然后按照“ ”進行行分隔,下面上個具體例子的代碼,供大家參考,有興趣的可以學習下。
process.stdin.resume(); process.stdin.setEncoding("ascii"); var input = ""; var input_array = ""; process.stdin.on("data", function (data) { input += data; }); process.stdin.on("end", function () { input_array = input.split(" "); var nLine = 0; while(nLine < input_array.length){ var line = input_array[nLine++].trim(); if(line === ""){ continue; } var input_arrays = line.split(" "); var a = +input_arrays[0]; var b = +input_arrays[1]; console.log(a+b); } });
五.總結
通過以上這種方式,應該能完成大部分的在線編程題,有需要的童鞋可以試試看。祝大家筆試順利,找到一份滿意的工作!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/87308.html
摘要:什么是單頁面應用單頁面應用是指用戶在瀏覽器加載單一的頁面,后續請求都無需再離開此頁目標旨在用為用戶提供了更接近本地移動或桌面應用程序的體驗。流程第一次請求時,將導航頁傳輸到客戶端,其余請求通過獲取數據實現數據的傳輸通過或遠程過程調用。 什么是單頁面應用(SPA)? 單頁面應用(SPA)是指用戶在瀏覽器加載單一的HTML頁面,后續請求都無需再離開此頁 目標:旨在用為用戶提供了更接近本地...
摘要:什么是單頁面應用單頁面應用是指用戶在瀏覽器加載單一的頁面,后續請求都無需再離開此頁目標旨在用為用戶提供了更接近本地移動或桌面應用程序的體驗。流程第一次請求時,將導航頁傳輸到客戶端,其余請求通過獲取數據實現數據的傳輸通過或遠程過程調用。 什么是單頁面應用(SPA)? 單頁面應用(SPA)是指用戶在瀏覽器加載單一的HTML頁面,后續請求都無需再離開此頁 目標:旨在用為用戶提供了更接近本地...
摘要:特意對前端學習資源做一個匯總,方便自己學習查閱參考,和好友們共同進步。 特意對前端學習資源做一個匯總,方便自己學習查閱參考,和好友們共同進步。 本以為自己收藏的站點多,可以很快搞定,沒想到一入匯總深似海。還有很多不足&遺漏的地方,歡迎補充。有錯誤的地方,還請斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應和斧正,會及時更新,平時業務工作時也會不定期更...
閱讀 2618·2021-11-12 10:36
閱讀 2257·2021-08-23 09:47
閱讀 1675·2019-08-30 15:44
閱讀 1400·2019-08-30 14:10
閱讀 2241·2019-08-29 16:52
閱讀 2333·2019-08-29 16:40
閱讀 1582·2019-08-29 16:17
閱讀 2407·2019-08-26 13:21