結果
問題 | No.316 もっと刺激的なFizzBuzzをください |
ユーザー |
![]() |
提出日時 | 2020-04-27 22:28:46 |
言語 | JavaScript (node v23.5.0) |
結果 |
AC
|
実行時間 | 78 ms / 1,000 ms |
コード長 | 2,178 bytes |
コンパイル時間 | 117 ms |
コンパイル使用メモリ | 6,696 KB |
実行使用メモリ | 40,448 KB |
最終ジャッジ日時 | 2024-10-13 01:45:22 |
合計ジャッジ時間 | 3,938 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 33 |
ソースコード
var reader = require('readline').createInterface({input: process.stdin,output: process.stdout});var obj = null;var inputFile = [];reader.on('line', function(input){inputFile.push(input);});reader.on('close', function(){obj = init(inputFile);Main();});function nextInt(){return myconv(next(),1);}function nextStrArray(){return myconv(next(),2);}//半角スペース分割function nextIntArray(){return myconv(next(),4);}//半角スペース + 数値化function nextCharArray(){return myconv(next(),6);}//1文字分割function next(){return obj.next();}function hasNext(){return obj.hasNext();}function init(input){var returnObj = {"list" : input, "index" : 0, "max" : input.length,"hasNext" : function(){return (this.index < this.max);},"next" : function(){if(!this.hasNext()){throw "ArrayIndexOutOfBoundsException これ以上ないよ";}else{var returnInput = this.list[this.index];this.index++;return returnInput;}}};return returnObj;}function myout(t){console.log(t);}//標準出力function myerr(t){console.error(t);}//標準エラー出力//[no]要素の扱い。数値型//不明値、異常時:引数そのまま返す 1:数値へ変換//2:半角SPで分割 4:半角SPで分割し、数値配列へ//6:1文字で分割 7:1文字で分割し、数値配列へ//8:半角SPで結合 9:改行で結合 0:文字なしで結合function myconv(i,no){try{switch(no){case 1:return parseInt(i);case 2:return i.split(" ");case 4:return i.split(" ").map((a)=>Number(a));case 6:returni.split("");case 7:return i.split("").map((a)=>Number(a));case 8:return i.join(" ");case 9:return i.join("\n");case 0:return i.join("");default:return i;}}catch(e){return i;}}function Main(){var N = nextInt();var two = nextIntArray();var a = two[0];var b = two[1];var c = two[2];var ab = lcm(a,b);var bc = lcm(c,b);var ac = lcm(a,c);var abc = lcm(a,lcm(b,c));myout(Math.floor(N / a) + Math.floor(N / b) - Math.floor(N / ab) + Math.floor(N / c) - Math.floor(N / bc) - Math.floor(N / ac) + Math.floor(N /abc));}function lcm(m, n) {return m * n / gcd(m, n);}function gcd(m, n) {return n != 0 ? gcd(n, m % n) : m;}