開発環境
- OS X Lion - Apple(OS)
- TextWrangler(Text Editor) (BBEditの機能制限無料版、light版)
- Script言語:Ruby
『初めてのプログラミング 第2版』(Chris Pine 著、長尾 高弘 訳、オライリー・ジャパン、2010年、ISBN978-4-87311-469-9)の 10章(章全部で復習), 10.3(練習問題)シャッフルを解いてみる。
その他参考書籍
- 『プログラミング言語 Ruby』David Flanagan, まつもと ゆきひろ 著 、卜部 昌平 監訳、長尾 高弘 訳、オライリー・ジャパン、2009年、ISBN978-4-87311-394-4)
- Rubyクックブック ―エキスパートのための応用レシピ集
シャッフル(再帰)
コード(TextWrangler)
sample.rb
#!/usr/bin/env ruby1.9
#-*- coding: utf-8 -*-
def shuffle some_array
recursive_shuffle some_array, []
end
def recursive_shuffle some_array, shuffled_array
a = Array.new(some_array)
return shuffled_array if a.length == 0
l = a.length
r = rand l
tmp = []
(0..(l-1)).each do |i|
if r == i
shuffled_array.push a[i]
else
tmp.push a[i]
end
end
recursive_shuffle tmp, shuffled_array
end
a1 = [1,2,3,4,5,6,7,8,9,10]
a2 = %w[a b c d e f g h i j]
[a1,a2].each do |a|
shuffled_a = shuffle a
puts "シャッフル前: #{a.join(",")}"
puts "シャッフル後: #{shuffled_a.join(",")}"
end
入出力結果(Terminal)
$ ./sample.rb シャッフル前: 1,2,3,4,5,6,7,8,9,10 シャッフル後: 2,8,5,4,3,9,6,1,10,7 シャッフル前: a,b,c,d,e,f,g,h,i,j シャッフル後: i,h,d,b,a,j,c,e,f,g $
0 コメント:
コメントを投稿