質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

1496閲覧

JavaScriptで、繰り返し処理と条件分岐を同時に行う方法を教えていただきたいです

moritat-222

総合スコア19

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/04/24 07:55

前提・実現したいこと

JavaScriptで、繰り返し処理と条件分岐を同時に行う時のやり方を教えていただきたいです。

現在、標準入力から受け取った値が、閏年に該当するかどうかのプログラムを作成しています。

標準入力では、一つ目に、何個の西暦を閏年と判断するか、それ以降に閏年かを判定する西暦を入力しています。

例)
2, 1996, 2010

標準入力で取得した値は、整数化してnum_lines()という配列に格納しています。
一つ目の標準入力は変数Nとして取得しています。

繰り返し文(for)を使って、num_lines[1]からnum_lines[N]までの値をひとつづつ取得し、
条件分岐(switch命令)を使って、それぞれが閏年に該当するか調べていこうとしているのですが、コードを動かしても正しく動いてくれません。

出力結果

'num_lines[i] is a leap year'

とだけ出力されてしまいます。

おそらく、繰り返し文を使ってnum_lines[i]に、num_lines[1]からnum_lines[N]までを一つづつ入れていく処理が
switch命令にうまく反映されていないのが原因なのではないかと思うのですが、改善方法がわかりません。

間違っている点を指摘していただきたく思います。

よろしくお願いいたします。

該当のソースコード

JavaScript

1//標準入力を取得 2process.stdin.resume(); 3process.stdin.setEncoding('utf8'); 4var lines = []; 5var reader = require('readline').createInterface({ 6 input: process.stdin, 7 output: process.stdout 8}); 9reader.on('line', (line) => { 10 lines.push(line); 11}); 12 13reader.on('close', () => { 14//受け取った標準入力を整数化 15 var num_lines = lines.map(function(num) { return num; }); 16//閏年かどうかを検討する西暦の数 17 var N = num_lines[0]; 18 19 for(i=1; i<=N; i++){ 20 21 switch(num_lines[i]){ 22 case 'num_lines[i] % 400 === 0': 23 console.log('num_lines[i] is a leap year'); 24 break; 25 case 'num_lines[i] % 100 === 0': 26 console.log('num_lines[i] is not a leap year'); 27 break; 28 case 'num_lines[i] % 4 === 0': 29 console.log('num_lines[i] is a leap year'); 30 break; 31 default: 32 console.log('num_lines[i] is not a leap year') 33 break; 34 } 35 } 36});

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

おそらく、繰り返し文を使ってnum_lines[i]に、num_lines[1]からnum_lines[N]までを一つづつ入れていく処理が

switch命令にうまく反映されていないのが原因なのではないかと思うのですが

違います。switchの条件の書き方が適当ではありません。

単に文字列を書いているだけなので、判定の条件が入力された文字列が、この文字列と一致するかになってしまっています。条件式として動作していません。

投稿2020/04/24 08:08

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2020/04/24 08:12

まずはループを回す前に、「1つの」日付に対するうるう年判定の処理を作ってください。
moritat-222

2020/04/24 10:14

回答ありがとうございます。 数式で処理すべきところを文字列として処理してしまっていたことに気付けました。 ただ、コードを修正しても、やはりうまくいかず、閏年として処理すべきところが「閏年ではない」と判定されてしまいます。全てswitch文のdefaultで処理されてしまっているところまでは分かったのですが、それがなぜなのか、自分では解決できませんでした。 改善したコードはこちらです。 よろしければ、間違っている点を指摘していただきたく思います。 よろしくお願いいたします。 //標準入力を取得 process.stdin.resume(); process.stdin.setEncoding('utf8'); var lines = []; var reader = require('readline').createInterface({ input: process.stdin, output: process.stdout }); reader.on('line', (line) => { lines.push(line); }); reader.on('close', () => { //受け取った標準入力を整数化 var num_lines = lines.map(function(num) { return num; }); //閏年かどうかを検討する西暦の数 var N = num_lines[0]; for(var i=1; i<=N; i++){ switch(num_lines[i]){ case num_lines[i] % 400 === 0: console.log(num_lines[i] + ' is a leap year'); break; case num_lines[i] % 100 === 0: console.log(num_lines[i] + ' is not a leap year'); break; case num_lines[i] % 4 === 0: console.log(num_lines[i] + ' is a leap year'); break; default: console.log(num_lines[i] + ' is not a leap year'); break; } } });
moritat-222

2020/04/24 12:37

解決できました!!! switch(num_lines[i]){ ではなく switch(true){ ですね!! ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問