結果
問題 |
No.935 う し た ぷ に き あ く ん 笑 ビ - ム
|
ユーザー |
![]() |
提出日時 | 2020-05-04 22:07:02 |
言語 | JavaScript (node v23.5.0) |
結果 |
AC
|
実行時間 | 288 ms / 2,000 ms |
コード長 | 2,396 bytes |
コンパイル時間 | 58 ms |
コンパイル使用メモリ | 6,688 KB |
実行使用メモリ | 48,116 KB |
最終ジャッジ日時 | 2024-10-13 01:46:55 |
合計ジャッジ時間 | 10,278 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 58 |
ソースコード
function main(input) { let [N] = getIntegers(input); let S = getStrings(input, ""); let A = getIntegers(input); let [Q] = getIntegers(input); let K = getIntegers(input); for(let i=0; i<Q; i++) { let max = 0; let sum = 0; let count = 0; let right = 0; for(let left=0; left<N; left++) { while(sum + A[right] <= K[i] && right < N) { if(S[right] == 'E') count++; sum += A[right]; right++; } max = Math.max(max, count); if(S[left] == 'E') count--; sum -= A[left]; } console.log(max); } } //-- functions ------------------------------------ function getIntegers(lines, sep=" ") { return lines.shift().split(sep).map(function(e) { return Number(e); }); } function getBigIntegers(lines, sep=" ") { return lines.shift().split(sep).map(function(e) { return BigInt(e); }); } function getStrings(lines, sep=" ") { return lines.shift().split(sep); } function twoDimenArrayByValue(h, w, value) { const list = new Array(h); for(let i=0; i<h; i++) { list[i] = new Array(w).fill().map(function(e) { return value.constructor == Array ? Array.from(value) : value; }); } return list; } function twoDimenArrayByStrings(h, strings) { const list = new Array(h); for(let i=0; i<h; i++) { list[i] = strings.shift().split(""); } return list; } function distance(x1, y1, x2, y2) { return Math.sqrt((x2-x1) * (x2-x1) + (y2-y1) * (y2-y1)); } function gcd(a, b) { return b === 0 ? a : gcd(b, a % b); } //-- Array ------------------------------------------- Array.prototype.deepCopy = function(list) { let retList = []; for(let i=0; i<list.length; i++) { retList[i] = list[i].constructor == Array ? Array.from(list[i]) : list[i]; } return retList; }; Array.prototype.out = function() { let outList = []; if(this[0].constructor == Array) { for(let i=0; i<this.length; i++) { outList.push(this[i].join(" ")); } } else { outList.push(this.join(" ")); } console.log(outList.join("\n")); }; Array.prototype.pushNoSameValue = function(...values) { values.forEach(function(e) { if(!this.includes(e)) { this.push(e); } }, this); }; Array.prototype.sortByIntegers = function() { this.sort(function(a, b) { return a - b; }); }; main(require("fs").readFileSync("/dev/stdin", "utf8").trim().split("\n"));