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

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

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

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

Q&A

解決済

1回答

8254閲覧

真ん中が「く」の平仮名三文字の言葉を「田」の形に並べるには?

manman

総合スコア233

Ruby

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

0グッド

1クリップ

投稿2015/04/29 11:06

編集2015/05/02 08:21


く_く_く

く_く_く


魔窟、旁、落馬、博打、読譜、袋、
枕、筑波、陸地、楽土、幕府、築炉

のように、
真ん中が「く」の平仮名三文字の言葉を「田」の形に並べる
(ただし、「く」で繋がれる文字は互いに異なるものとする。)
にはどうすればよいでしょうか?

以下のコードは、
皆様が回答されるうえで何か役に立つかもしれないので
載せておきます。

lang

1# -*- coding: cp932 -*- 2words = [ 3'あくび', 'あくま', 4'いくじ', 'いくら', 5'えくぼ', 6'おくて', 'おくば', 7'かくご', 'かくさ', 'がくし', 'かくほ', 'かくり', 8'ごくい', 'こくし', 9'さくが', 'さくし', 'さくら', 'ざくろ', 10'しくみ', 11'すくい', 12'そくい', 13'たくじ', 'たくち', 14'ちくま', 'ちくろ', 'ちくわ', 15'つくし', 'つくば', 'つくり', 16'てくだ', 17'とくぎ', 'とくし', 'どくふ', 'どくろ', 18'はくい', 'はくし', 'ばくし', 'ばくち', 'ばくふ', 'ばくろ', 19'びくに', 20'ふくい', 'ふくし', 'ふくつ', 'ふくろ', 21'ぼくし', 'ほくろ', 22'まくつ', 'まくら', 23'もくじ', 'もくず', 24'やくみ', 'やくめ', 25'らくだ', 'らくど', 'らくば', 26'りくち' 27] 28 29ary = ['ち', 'つ', 'ど', 'ば', 'ふ', 'ま', 'ら', 'り', 'ろ'] 30 31ary.permutation(9){|a| 32 i = 0 33 while (words.include?(a[i] + 'く' + a[i + 1]) || i % 3 == 2) && i < 7 34 i += 1 35 end 36 if words.include?(a[i] + 'く' + a[i + 1]) 37 j = 0 38 while words.include?(a[j] + 'く' + a[j + 3]) && j < 5 39 j += 1 40 end 41 if words.include?(a[j] + 'く' + a[j + 3]) 42 (0..2).each{|k| 43 puts a[3 * k] + 'く' + a[3 * k + 1] + 'く' + a[3 * k + 2] 44 puts 'く く く' if k < 2 45 } 46 puts '' 47 end 48 end 49}

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

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

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

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

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

guest

回答1

0

ベストアンサー

予め各単語の末尾に接続できる単語は求めておいて、
縦の制約は都度満たしているかどうか判断する方式にしました。

lang

1#coding: Windows-31J 2words = [ 3'あくび', 'あくま', 4'いくじ', 'いくら', 5'えくぼ', 6'おくて', 'おくば', 7'かくご', 'かくさ', 'がくし', 'かくほ', 'かくり', 8'ごくい', 'こくし', 9'さくが', 'さくし', 'さくら', 'ざくろ', 10'しくみ', 11'すくい', 12'そくい', 13'たくじ', 'たくち', 14'ちくま', 'ちくろ', 'ちくわ', 15'つくし', 'つくば', 'つくり', 16'てくだ', 17'とくぎ', 'とくし', 'どくふ', 'どくろ', 18'はくい', 'はくし', 'ばくし', 'ばくち', 'ばくふ', 'ばくろ', 19'びくに', 20'ふくい', 'ふくし', 'ふくつ', 'ふくろ', 21'ぼくし', 'ほくろ', 22'まくつ', 'まくら', 23'もくじ', 'もくず', 24'やくみ', 'やくめ', 25'らくだ', 'らくど', 'らくば', 26'りくち' 27] 28 29def gen_connect_info(words) 30 connect_info = {} 31 32 words.each do |word| 33 connect_info[word] = [] 34 words.each do |w| 35 if word[-1] == w[0] && word != w 36 connect_info[word] << w 37 end 38 end 39 end 40 41 connect_info 42end 43 44def print_answer(words) 45 puts words.each_slice(2).map{|w1, w2| 46 w1 + w2[-2 .. -1] 47 }.join("\nく く く\n") 48 49 puts 50end 51 52def unused_list(words, used) 53 words.select{|e| !used.include?(e)} 54end 55 56def check_exists_and_unused(w, connect_info, used) 57 connect_info[w] && !used.include?(w) 58end 59 60def search_pattern(i, max_size, connect_info, acc=[], used = []) 61 if i >= max_size 62 print_answer(acc) 63 else 64 words = unused_list(connect_info.keys, used) 65 words.each do |w| 66 unused_list(connect_info[w], used).each do |w2| 67 prev1, prev2 = acc[-2 .. -1] 68 if prev1 69 v1 = prev1[0] + "く" + w[0] 70 v2 = prev1[-1] + "く" + w[-1] 71 v3 = prev2[-1] + "く" + w2[-1] 72 if check_exists_and_unused(v1, connect_info, used) && 73 check_exists_and_unused(v2, connect_info, used) && 74 check_exists_and_unused(v3, connect_info, used) && 75 search_pattern(i + 1, max_size,connect_info, acc + [w, w2], used + [w, w2, v1, v2, v3]) 76 end 77 else 78 search_pattern(i + 1, max_size, connect_info, acc + [w, w2], used + [w, w2]) 79 end 80 end 81 end 82 end 83end 84 85connect_info = gen_connect_info(words) 86#p connect_info 87search_pattern(0, 3, connect_info) 88

投稿2015/04/30 09:34

pocari

総合スコア9

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問