challenge ビンゴの結果を整形表示

重複無し乱数」の続編です。

「重複無し乱数」で作ったbingo関数の結果を下のように「何番目の乱数か」とセットにして10個ずつ折り返して表示するコードを書いてください。

>>> bingo(30)
  1  2  3  4  5  6  7  8  9 10
 29 14 16 13 30 15 22 11 25  9

 11 12 13 14 15 16 17 18 19 20
 23  4 18  5 28 17  8 12 21 20

 21 22 23 24 25 26 27 28 29 30
 26  6  2 19  1  7 10 27  3 24

>>> bingo(35)
  1  2  3  4  5  6  7  8  9 10
  7 15  3 32  1 16 17 28  6 29

 11 12 13 14 15 16 17 18 19 20
 19 23 30 26 20  5 12  2 25 31

 21 22 23 24 25 26 27 28 29 30
 35 13 24 18 11  8 10 34 22 21

 31 32 33 34 35
  9  4 27 33 14

Posted feedbacks - Prolog


	
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
shuffle([], []).
shuffle(X, [R|Y]) :- length(X, XL), N is random(XL),
	nth0(N, X, R), select(R, X, X1), shuffle(X1, Y).

write_row(L, W) :- write_row(L, W, W).
write_row(   [], _,   _) :- nl.
write_row([X|L], W, Tab) :- format('~t~d~*|', [X, Tab]),
	Tab1 is Tab + W + 1, write_row(L, W, Tab1).

write_bingo(W, X, S) :-
	length(X, N), N > 10,
	nth0(10, X, XE), append(XL, [XE|XR], X),
	nth0(10, S, SE), append(SL, [SE|SR], S),
	write_row(XL, W), write_row(SL, W), nl,
	write_bingo(W, [XE|XR], [SE|SR]).
write_bingo(W, X, S) :- write_row(X, W), write_row(S, W).

bingo(N) :- findall(X, between(1, N, X), L), shuffle(L, S), 
	atom_number(A, N), atom_length(A, T), write_bingo(T, L, S).

Index

Feed

Other

Link

Pathtraq

loading...