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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Q&A

解決済

2回答

474閲覧

チェックディジットのロジックについて

kenya.yasuhara

総合スコア17

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

0グッド

0クリップ

投稿2019/06/04 00:05

前提・実現したいこと

Rubyでチェックディジットを完成させたいです。
従うルールとして
・偶数桁の数字をそれぞれ2倍し総和をとったものをeven
(ただし、2倍したあと2桁の数字になるものは、1の位と10の位の数を足して1桁の数字にしたあと、総和をとる)
・奇数桁の数字の総和をとったものをoddとすると、even + odd は10 で必ず割り切れる
があります。

発生している問題・エラーメッセージ

後々配列evenと配列oddの中身をstringではなくintegerの状態で使いたいので、
28行目〜33行目ではevenoddの中身はintegerにしたいです。

その方法がわかりません。

該当のソースコード

Ruby

1even_nums = [] #偶数番目のみの配列 2odd_nums = [] 3even = [] #偶数番目を計算した値 4odd = [] 5 6# 繰り返しの回数を受け取る 7rpt = gets.to_i 8 9# 入力値からXを除く 10rpt.times do 11 input_card_values = gets.chomp 12 card_nums = input_card_values.chars 13 card_nums.delete("X") 14 15 # evenとoddにわけて配列を作る(でないと次の工程で偶数番目と奇数番目をごちゃまぜで計算することになるため) 16 even_nums = card_nums.each_slice(2).map(&:first) 17 odd_nums = card_nums.select.with_index{|content, index| 18 content.to_i 19 index.to_i 20 index % 2 == 1 21 } 22 p even_nums 23 p odd_nums # ここまでクリア 24 #even_numsとodd_numsをルールに従い配列にし直す 25 even_nums.each do |even_num| 26 # even_numsの要素が2桁だった場合、十の位と一の位も数字を足す 27 if (even_num.to_i * 2).to_s.length == 2 28 even = (even_num.to_i * 2).to_s.split("").inject{|ten, one| ten + one} 29 else 30 even << even_num 31 end 32 end 33 odd = odd_nums.sum 34 p even 35 p odd 36#even + oddが10で割り切れることからxをもとめる 37 (0..9).each do |x| 38 if (even + odd + x) % 10 == 0 then 39 break 40 end 41 puts x 42 end 43end 44 45 46 47# [[8, 4, 6, 0, 8, 7, 7, 2, 9, 1, 2, 8, 5, 6, 9, X], [1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, X], 48 49# 8 6 8 7 9 2 5 9 偶: even 50# 4 0 7 2 1 8 6 X 奇: odd 51# even = 7 3 7 5 9 4 1 9 = 45 52# odd = 28 + x 53# even + odd = 73 + x 54# x = 7

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

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

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

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

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

arcanum_jp

2019/06/04 00:20 編集

*(削除しました)
asm

2019/06/04 03:16 編集

~~Rubyのバージョンとして2.4.0未満を切り捨てられますか?~~ よく考えたらいらんかった。
guest

回答2

0

ベストアンサー

色々問題有りですね。
これは文字列なのか、整数なのか、配列なのか、を常に意識しながらプログラムを書く必要があります。
また、入力した直後に、to_iして以降はずっと整数で扱うのが良いと思います。

「引数で、整数値の配列を与えると、結果を計算して返してくれる」というメソッドをまず書いて、テストして、その後で、getsしながらそのメソッドを呼び出すメイン処理を書くといいです。

とりあえず、最小限の修正で済ませると、

Ruby

1 even = [] 2 even_nums.each do |even_num| 3 # even_numsの要素が2桁だった場合、十の位と一の位も数字を足す 4 if (even_num.to_i * 2).to_s.length == 2 5 even << (even_num.to_i * 2).to_s.split("").inject{|ten, one| ten.to_i + one.to_i} 6 else 7 even << even_num.to_i 8 end 9 end 10 even = even.sum 11 odd = odd_nums.map(&:to_i).sum

あと、最後に10で割り切れたときに、何も表示しないのはおかしいのでは?

投稿2019/06/04 16:29

otn

総合スコア84505

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

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

0

even = (even_num.to_i * 2).to_s.split("").inject{|ten, one| ten + one}

ruby

1even = (even_num.to_i * 2).divmod(10).sum

投稿2019/06/04 03:19

asm

総合スコア15147

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問