RUBYの宿題教えてくだ ..
[2ch|▼Menu]
263:デフォルトの名無しさん
06/05/30 14:32:48
じゃんけんだと、手の種類が2個だと勝敗が決まってるんだよな。
3のときと1のときはあいこだよな。
いちいち判定しないで
#仮想コード
players.find(winner_hand(*hands.uniq)) if hands.uniq.size == 2
とかでいけるんじゃないの?

Handクラスを作ってTyoki<-Paa<-Goo<-Tyokiとリンクリストみたいにして負けた方をincompatibleとして持つなら
def stronger(other)
@incompatible == other ? self : other
end
これだとwinner_handはいらなくて、
hands.uniq.inject{|a,b| a.stronger b}/*hands.uniq.size == 2*/で勝つ方の手が決まる。
まあ真偽値返すようにしてsortして[0]使うんでもいいけど。
Tyokiとかはインスタンスが違っちゃいかんのでHansの定数にするかシングルトンにするかクラスのまま使うかすること。

あとloopでgame呼ばないでgame側でloopしたほうがよさそうなのと
win_patternは普通にクラス定数の方がいいんじゃねえかと思うのと
gameでwinnerに@playersを代入してるけどインスタンス変数のまま使えばいいじゃんってのと
コンストラクタでやってる色々は引数にした方がいいんじゃねえかとか。

あとオブジェクト指向っぽくするならCOMPlayerとHumanPlayerを作ってVisitorパターン使ってplayさせてみるとか。
といってもVisitorパターンが最適とは本見なきゃわからん人なので今ひとつ断言できない。

264:デフォルトの名無しさん
06/05/30 16:24:06
じゃんけんが完成したら、いよいよ野球拳の実装だな。wktk

265:デフォルトの名無しさん
06/05/30 18:39:19
オセロまでいくとむずすぎる?

266:デフォルトの名無しさん
06/05/30 18:55:58
頭の悪いオセロなら簡単だよ

267:デフォルトの名無しさん
06/05/31 04:16:01
それオセーロ

268:259
06/05/31 07:17:44
遅くなってすみません。
URLリンク(sourcepost.sytes.net)

Rubyに移植済みのもの。
判定部分に剰余を使っているので三人でしかじゃんけんできません。

あと、ルール
一人勝ちなら+2ポイント残り二人は-1ポイントずつ
二人勝ちなら+1ポイントずつ残り一人は-2ポイント
終了条件は特に無し

# EUC-JPなファイルをupしたら文字化けorz

269:デフォルトの名無しさん
06/05/31 14:02:51
>>268
URLリンク(sourcepost.sytes.net)
Rubyっぽくしてみた。
ルール(配点)の入れどころがよくわからんかったので消してしまったがJanken側にあるべきではないか。

$ ruby source.rb プレーヤ数 回数
で実行できるけど30人越えた辺りで反応がすげー鈍くなるよ。


270:268
06/05/31 19:56:37
>>269
うーん、Rubyだ。

ポイントの入れ方は、3人でじゃんけんして
あいこなら変化なし
一人勝ちなら勝った人は+2point,負けた二人は-1pointずつ
二人勝ちなら勝った二人は+1pointずつ,負けた人は-1point
# ダメな変数の使い方の見本になってしまったorz
# flagに複数の意味を持たせてしまっていたようだ
# いくら一年以上前のプログラムだからって気付けよ>一昨日の自分

確かに、配点を弄るメソッドがPlayerにあるのは変ですね。
Jankenクラスにjudgeメソッドを実装するなら、ポイントを弄るメソッドも
Jankenクラスにあるべきですね。

>268の時点では、Jankenクラスは特に役目は無くて(ってまたダメな設計の見本orz)
単にゲームを開始するだけの係りでした。


271:デフォルトの名無しさん
06/05/31 20:38:13
>>269
>>263の人?
初心者だけど、Rubyの勉強になった。サンクス。
2時間ぐらいマニュアルと格闘しながら解読した。

272:デフォルトの名無しさん
06/06/01 13:08:46
Jankenにポイント計算つけた。
URLリンク(sourcepost.sytes.net)
(敗者数/勝者数).ceilのポイント(敗者数>勝者数、そうでなければポイント=1)を分ける。
敗者は常に-1にしてある。
3人でやったときは同じ結果で、それ以上でも同じルールをスケールした結果になるはず。


273:デフォルトの名無しさん
06/06/01 19:51:06
>>272
本当に些細なことだが、
scissorsは単複同形だよ。

274:デフォルトの名無しさん
06/06/02 01:38:55
N人であいこなし。複数人が勝てるパターンにしてみた。
URLリンク(sourcepost.sytes.net)

使い方は>269と同じ(パクりました)
* 変数名、メソッド名を自分の好みに変更
* 判定にビット演算を使いたかったので、手の定義を変更した。
* 対話的に動かせるようにしてみた。
* 回数が多いときは誰かが101勝したら終了
* 人数を増やしすぎると延々あいこが続くので決着が着かない

例えば、
$ ruby Janken.rb 3 10
なら、3人で10回勝負が着くまでじゃんけんしつづける。

# あいこでredoさせるのに手間取った
# Fixnum#stepでredoすると最初からになってしまうorz
# 人数が多い時は別の終了条件にした方が良さそう。
# おいらが書くと長くなってしまうorz

275:デフォルトの名無しさん
06/06/03 15:28:38
age

276:デフォルトの名無しさん
06/07/16 14:47:02
すいません。
ある文字列があったときに、特定の範囲の文字色を変えるというプログラムをつくりたいのですが、
どなたかアドバイスお願いします。

いまはHTMLで出力しているのですが、それ以外にも、ruby/tkでつくったプログラム上に表示したいと思っています。


277:デフォルトの名無しさん
06/07/16 15:07:20
file=File.read('test.txt')

rules=[
  {'re' => /cat/ ,'from' => 'ねこだいすき', 'to' => '<font color=red>ねこだいすき</font>'},
  {'re' => /dog/, 'from' => 'いぬだいすき', 'to' => '<font color=blue>いぬだいすき</font>'}
]

rules.each do |rule|
  if file =~ rule['re'] then
    file.gsub(rule['from'],rule['to'])
  end
end


#アドバイスって何が欲しいんだろう…

278:デフォルトの名無しさん
06/07/17 04:44:43
宿題スレ向きだよな。
アドバイスじゃなくて正解が知りたいと思う悪寒。

こう試してみたけど出来ませんじゃないし。

279:デフォルトの名無しさん
06/07/17 10:32:52
ここ宿題スレだよね

280:デフォルトの名無しさん
06/07/17 11:33:00
宿題隔離スレだから自力でできた(できてない)とこから以下全部丸投げとかでも構わない
こんなとこで一言一句完全丸写ししてバレないと思ってるならそれでもいいし

ただし問題が何したいのかさっぱりわからん場合はそれこそ問題外

281:デフォルトの名無しさん
06/07/17 11:45:35
問題文さえここに正確に書き写せない香具師なんだからどうなっても知らん

282:デフォルトの名無しさん
06/07/24 21:22:49
さっぱりわかりません。どうかよろしくお願いします。

URLリンク(kansai2channeler.hp.infoseek.co.jp)

283:デフォルトの名無しさん
06/07/24 21:32:58
ar.push ar.shift


284:デフォルトの名無しさん
06/07/24 21:48:13
これもわかりません。どうか優しい人よろしくお願いします。

URLリンク(kansai2channeler.hp.infoseek.co.jp)

285:デフォルトの名無しさん
06/07/24 21:51:24
>>283
その日の授業内容にもよるが先生が頭抱えそうな回答だな(w

286:デフォルトの名無しさん
06/07/24 21:59:40
>282,284
っていうか教科書読めよ。

特に 284 なんて問題文に答えが書いてあるのにこれ以上優しく説明できるか。


287:デフォルトの名無しさん
06/07/24 23:23:54
x = ARGV[0].to_i
if /[05]$/ =~ x.to_s
print "#{x}は5の倍数です。\n"
end
if /^(([0369]|[258][0369]*[147])|([147]|[258][0369]*[258])([0369]|[147][0369]*[258])*([258]|[147][0369]*[147]))*$/ !~ x.to_s
print "#{x}は3の倍数ではありません。\n"
end

288:デフォルトの名無しさん
06/07/25 01:02:30
>>287
ありがとうございました!!!!!
本当に助かりました!

289:デフォルトの名無しさん
06/07/25 14:27:15
>>283>>287を提出したのだろうか

290:デフォルトの名無しさん
06/07/25 20:27:32
283はいいと思うけど、287はちょっとなぁ。

291:デフォルトの名無しさん
06/07/25 20:32:00
>>282も配列の添え字の勉強をした上での宿題なんじゃないかと思うぞ…

292:デフォルトの名無しさん
06/07/25 21:19:06
>>287の3の倍数でない方がよくわからん。
3で割り切れないじゃダメなの?

293:デフォルトの名無しさん
06/07/25 21:23:40
5の倍数のとこをよく読んで意図を掴め

294:デフォルトの名無しさん
06/07/26 02:42:09
ARGV[0].to_s.split(//)#!/usr/bin/ruby

def sm(s)
sm = 0
s.to_s.split(//).each {|e|
sm += e.to_i
}
sm = sm(sm) if(sm >= 10)
return sm
end

f = [true, false, false, true, false, false, true, false, false, true]
p f[sm(ARGV[0])]



295:デフォルトの名無しさん
06/07/26 02:42:50
ゴミがついたので貼りなおし

#!/usr/bin/ruby

def sm(s)
sm = 0
s.to_s.split(//).each {|e|
sm += e.to_i
}
sm = sm(sm) if(sm >= 10)
return sm
end

f = [true, false, false, true, false, false, true, false, false, true]
p f[sm(ARGV[0])]

296:デフォルトの名無しさん
06/07/26 02:45:06
文字が入力されてたらアウトだからこうかな


#!/usr/bin/ruby

def sm(s)
sm = 0
s.to_s.split(//).each {|e|
sm += e.to_i
}
sm = sm(sm) if(sm >= 10)
return sm
end

p [false, false, false, true, false, false, true, false, false, true][sm(ARGV[0]
)]


297:デフォルトの名無しさん
06/07/26 18:19:26
x = ARGV[0].to_i
if ("x" * x).gsub(/xxx/,'') !~ /x/
print "#{x}は3の倍数ではありません。\n"
end

298:デフォルトの名無しさん
06/07/28 00:58:09
どうか助けてください。

URLリンク(kansai2channeler.hp.infoseek.co.jp)

299:デフォルトの名無しさん
06/07/28 01:13:51
またお前あるいは同類か

どうでもいいがこれまで言われたアドバイス全然生かしてねえな

300:デフォルトの名無しさん
06/07/28 01:17:03
授業で習ってない書き方をしたら丸写しバレるだろって話ね(w

301:デフォルトの名無しさん
06/07/28 01:39:33
こんなに答えの書いてある問題はさすがにないと思うんだが、本当に宿題なのかなあ。


302:デフォルトの名無しさん
06/07/28 01:43:07
>>301
すまん、こういうパズル未満の難易度の言葉合わせな宿題は出る。
授業聞いてればそれなりに何使うかは思いつくだろ、みたいな。
情報でのプログラムの演習なんてその程度でいいんだよ。

303:デフォルトの名無しさん
06/07/28 01:47:16
>>298
てゆーかさ、これだとpflagはずっとtrueのままじゃね?

304:デフォルトの名無しさん
06/07/28 01:53:24
>>298
include Math
n = ARGV[0].to_i
ne = sqrt(n).to_i
pflag = true
for i in 2..ne
 break if pflag = n % i == 0
end
puts pflag ? 'xx は合成数です' : 'xx は素数です'

俺にはこれが限界
後は誰か頼む

305:デフォルトの名無しさん
06/07/28 01:57:00
プログラムが書けるより、問題を論理的に解析して解の生成アルゴリズムをひらめくのが重要。
アルゴリズムがひらめけばあとは言語仕様に従って記述すればプログラムに成るし。

306:ど素人
06/07/28 02:01:09
参考書にてわからない問題がありました。次のプログラムって日本語でどう説明できますか?
ぜひお願いします。
A=new Array(3, 8, 19, 20, 22, 24, 45);
i=0;
j=A.length-1;
a=19;
k=Math.floor((i+j)/2);
while(i<=j){
if(A[k] == a){
break;
}
else if(A[k] > a){
j = k - 1;
}
else{
i = k + 1;
}
k = Math.floor((i+j)/2);
}
if(i>j) k=-1;
document.write(a," ",k);



307:デフォルトの名無しさん
06/07/28 02:06:14
>>306
Rubyじゃないじゃん。

308:デフォルトの名無しさん
06/07/28 02:15:10
javascriptか
言語ですらないな
板違いだ

309:デフォルトの名無しさん
06/07/28 02:20:29
JavaScriptの言語性を馬鹿にしていると痛い目見るぞ

310:デフォルトの名無しさん
06/07/28 02:32:19
>>309
馬鹿にされたと思ったあなたは >>306 ですか?

311:デフォルトの名無しさん
06/07/28 09:16:50
どこをどう読めば人を馬鹿にしてると読めるんだろう

312:デフォルトの名無しさん
06/07/28 09:26:32
馬鹿な人がいるようには読める。

313:デフォルトの名無しさん
06/07/28 10:32:03
馬鹿な人には読めないマキコ。

314:デフォルトの名無しさん
06/07/28 13:19:12
どっちにしろ荒らしに反応すな

315:デフォルトの名無しさん
06/07/28 16:16:36
js=ajax=web2.0

316:デフォルトの名無しさん
06/08/26 13:24:41
もしかしたらスレ違いかも知れませんが…

コマンドラインから
テキストファイルを、各行の頭に行番号を付け表示したいのです。
今は Ruby で

ruby -e 'a=readlines;for i in 0...a.size;printf"%6d: %s",i+1,a[i];end' textfile

としています。
でももう少し短くなる気がするのですが、良いワンライナー無いでしょうか?

317:デフォルトの名無しさん
06/08/26 14:03:40
ruby -ple 'printf "%6d: ", $.'

318:デフォルトの名無しさん
06/08/26 14:07:40
ruby -e 'exec("/bin/cat", "-n", *ARGV)'

319:デフォルトの名無しさん
06/08/26 14:16:06
ruby -e 'ARGF.each{|s|printf "%6d: %s", ARGF.file.lineno, s}'

320:316
06/08/26 17:00:01
>>317
短ッ!rubyのオプションと特殊変数の事
すっかり忘れてました、感謝です

>>318
環境書き忘れてた…今度リナやユニ触る機会があったら
catのオプションの事思い出します

>>319
ARGF.eachはさっき気付いて
i=0;ARGF.each{|s|printf "%6d: %s",i+=1,s}
って書いたところでした

そういやARGFは独自のメソッド持ってるんでしたね…

321:デフォルトの名無しさん
06/08/30 11:56:52
>>320
> i=0;ARGF.each{|s|printf "%6d: %s",i+=1,s}

そういうときはwith_index使えって教わんなかったか?
ARGF.each_with_index{|s, i|printf "%6d: %s", i, s}


322:デフォルトの名無しさん
06/08/31 22:22:15
二進表示をprintf,sprintfを使わず、正の整数を入力して
その二進表示を出力するプログラムを作成しよ。
ただし整数から二進表示文字列を作るメソッドi2bを
作成してそれを呼び出すように書くこと。

できるだけ簡単なプログラムでお願いします。
Ruby初心者なのでわからなくて困ってます。



323:デフォルトの名無しさん
06/08/31 22:35:13
>>322
alias myprintf printf
myprintf("%b\n", 10) #=> 1010


324:デフォルトの名無しさん
06/08/31 22:38:35
>>323
ありがとうございます。
でも、せっかく作成していただいたのに申し訳ないのですが
printfは使って作成してはいけないんです。


325:デフォルトの名無しさん
06/08/31 23:05:24
ちっ、バレたかwww

326:デフォルトの名無しさん
06/08/31 23:05:42
>>322
こんなんじゃダメ?

def i2b i
return i.to_s(2)
end

327:デフォルトの名無しさん
06/08/31 23:16:24
Fixnum < Integer#to_s
--- to_s
--- to_s(base) ruby 1.7 feature

整数を 10 進文字列表現に変換します。

ruby 1.7 feature: 引数を指定すれば、それを基数とした文字列表
現に変換します。基数として 2 〜 36 以外を指定した場合は例外
ArgumentError が発生します。

p 10.to_s(2) # => "1010"
p 10.to_s(8) # => "12"
p 10.to_s(16) # => "a"
p 35.to_s(36) # => "z"

これか。
これ提出されたら、宿題だした奴もがっくり来るだろうなw

328:デフォルトの名無しさん
06/08/31 23:28:58
>>326>>327
ありがとうございます。
家のパソコンだとプログラムが実行できないので
明日実行できるパソコンで試してみます。

329:デフォルトの名無しさん
06/08/31 23:29:00
超ナイーブに書いてみたが数字がでかいとスタックオーバーフローで死ぬ。
def to_bin(i); q, m = i.divmod(2); q == 0 ? m : to_bin(q).to_s + m.to_s;end

330:デフォルトの名無しさん
06/08/31 23:34:27
>>328
家のパソコンにもRubyインストールすればいいだろ?
よっぽど特殊なOSで無い限り入れられる。

331:デフォルトの名無しさん
06/08/31 23:42:20
329>>
何回もインストールしてみたのですが
何回挑戦しても失敗してしまいます。



332:デフォルトの名無しさん
06/08/31 23:55:11
>>331
URLリンク(rubyforge.org)
URLリンク(instantrails.rubyforge.org)

どっちでも好きな方を試せ。
使い方は聞くな。


333:デフォルトの名無しさん
06/09/01 00:00:08
最近は宿題もWeb2.0とか意識するべきだと思うんだ


def i2b(i)
require "open-uri"
open('URLリンク(google.co.jp)'+i+'+in+binary').read.scan(/0b([01]+?)</)
end

puts "正の整数を入れてください"
i=STDIN.gets.chomp
puts i2b(i)


334:デフォルトの名無しさん
06/09/01 00:03:39
332>>333>>
ありがとうございます。
助かりました。

335:デフォルトの名無しさん
06/09/01 00:13:12
web 2.0ってperl廚の妄言のような。
phpとの戦いで死にかけてるから生き残りに必死な様にしか見えない。

336:デフォルトの名無しさん
06/09/01 00:17:55
>>335
そうか?PHPってgoto導入して死ぬんだろ?

337:デフォルトの名無しさん
06/09/01 00:20:51
Web2.0は言語を規定しない(そもそも何も規定しないがw)

「なんかWeb通して新感覚にみんなで超便利」というサービスを提供する限り、
サーバー上の言語は本当に何でもよい

338:デフォルトの名無しさん
06/09/01 00:43:49
初心者の自分が作った方が参考になるんじゃないのかな?

def i2b i
b = "" # 2進法文字列の初期化

while i>0
if i%2 == 1 then # 2で割って余りをもとめる
b = "1" + b # 1なら文字列の先頭に1を追加
else
b = "0" + b # 0なら文字列の先頭に0を追加
end
i = i/2
end

return b
end

339:デフォルトの名無しさん
06/09/01 01:06:58
def i2b(i)
  cc = nil
  b = ""
  if i = callcc {|cc| i}
    b = "01"[i % 2] + b
    cc.call((i / 2).nonzero?)
  end
  b
end


340:デフォルトの名無しさん
06/09/01 09:53:17
>>338
わかりやすく教えていただいて
ありがとうございます。
>>339
ありがとうございました。

341:デフォルトの名無しさん
06/09/01 11:03:29
>>338
参考にはなるかもしれんが、ためにはならんぞ。

342:デフォルトの名無しさん
06/09/09 05:00:57
Rubyで書かれたうpろだのソースってありますか?

343:デフォルトの名無しさん
06/09/09 11:31:05
ハイレベルな宿題だな

344:デフォルトの名無しさん
06/09/09 19:34:15
>>342
cgi限定?
http以外のプロトコル使ってもいいのかな?


345:デフォルトの名無しさん
06/09/09 21:53:01
AppleTalkでお願いします。

346:デフォルトの名無しさん
06/09/10 18:06:15
>>342
ここにあるよ
URLリンク(wirepuller.org)

347:デフォルトの名無しさん
06/09/11 16:25:43
>>346
ありがとうございます。
CGI.rbの仕様で10kB以下だとStringIOで処理されて
それ以上のサイズだとTempfileオブジェクトになるようだと
書いてあるのですが
「Tempfileの場合、数MBのファイルをread,writeするのはあれなので」
という部分の意味が良く分かりません
何があれなんでしょうか

348:デフォルトの名無しさん
06/09/11 16:43:40
やっぱり、なにがあれなんだろう。

349:デフォルトの名無しさん
06/09/11 16:47:04
「数MBのファイルを、わざわざ Ruby の read/write を使ってアップローダ側
のディレクトリの特定のファイルにコピーするのは処理にオーバヘッドがかか
るので」

てとこじゃね。

350:デフォルトの名無しさん
06/09/11 16:51:16
ああでもあれか、 FileUtils.cp ってけっきょく ruby レベルで read/write
を繰り返しているわけだよな。まあ、当り前だが。

それに、ソースを見てみると file.size の大小で TempFile かどうか判定し
てるね。 is_a? とかを使った方がいいんじゃないかなあ。


351:デフォルトの名無しさん
06/09/11 22:39:34
multipart/form-dataってファイル毎のデータ長送ってこない上に、次にどのファイル(or フォームのクエリ)が来るか分からないんだっけ。
だから便利性を求めたライブラリは、テンポラリファイル作るとか回りくどい仕様になってるんだよね。

こういうインターフェイスにすれば、少し面倒になるけど
テンポラリも要らないし融通が利くのに。

cgi = CGI.new
cgi.find_file {|info, fp|
 # フォームから送られた名前で振り分け
 if info.name == "upload_file"
  # fpを使ってファイルに保存する処理
 else
  # 普通のクエリとして扱う
  cgi[info.name] = fp.read
 end
}

352:デフォルトの名無しさん
06/09/15 02:07:28
def seach(dir, key)

dir(ディレクトリ), key(検索キーワード)
で指定したディレクトリ下にある合致するファイルを検索して
合致するファイル名の配列を返す関数のコードお願いします。

353:デフォルトの名無しさん
06/09/15 02:52:35
自分で出来ました。お騒がせしました。

def seach(dir, key)
a = Array.new

Dir.foreach(dir){|f|
if f[key]
a.push(f)
end
}

a
end

seach(Dir.getwd, ".txt").each{|v|
print v + "\n"
}

354:デフォルトの名無しさん
06/09/15 04:44:56
Dir.glob(dir + "/**/" + key)
じゃ駄目?

355:デフォルトの名無しさん
06/09/15 09:46:53
合致するファイルって名前だけか。


356:デフォルトの名無しさん
06/09/15 12:35:15
353.gsub(/serch/, 'search')

357:デフォルトの名無しさん
06/09/15 12:36:53
353.gsub(/seach/, 'search')

358:デフォルトの名無しさん
06/09/15 13:35:36
353.gsub /(?=。)/, "お"

(^ω^ )

359:デフォルトの名無しさん
06/09/19 05:01:46
数字に変換できなくなるまで、入力を何回でも受け付けるプログラムを
作りました。入力された文字列が数字に正しいものかどうかをチェック
するようなフィルタを作ったんですが、あまりスマートに書けませんで
した。もう少し、きれいなコードを書く方法をご存知の方、ご意見を下
さい。
#!/usr/bin/ruby
def i2b (i) ;return i.to_s(2) ;end
#文字列が数値に変換可能かチェックする 0xffはOK 124ffはNG
def analyzer (str) #if str can be converted to number => true else => false
str.delete!("\n");str.downcase!
case str[0..1]
when '0x'
num = str.to_i(16)
if num.to_s(16) != str[2..-1] ;return false ;end
when '0b'
num = str.to_i(2)
if num.to_s(2) != str[2..-1] ;return false ;end

360:デフォルトの名無しさん
06/09/19 05:03:41
when '0d'
num = str[2..-1]
if num.to_s(10) != str[2..-1] ;return false ;end
when '0o'
num = str.to_i(8)
if num.to_s(8) != str[2..-1] ;return false ;end
else
if str[0] == '0'[0] and str.length > 1
num = str.to_i(8)
if num.to_s(8) != str[1..-1] ;return false ;end
elsif str[0] != '0'[0]
num = str.to_i(10)
if num.to_s(10) != str ;return false ;end
end
end
return true
end
puts "please input number."
loop{
print ">" ;str = gets()
if analyzer(str) == false ;puts "#{str} is not number" ;exit ;end
num = str.to_i(0) ;puts i2b(num)
}


361:デフォルトの名無しさん
06/09/19 13:54:30
age

362:デフォルトの名無しさん
06/09/20 00:09:54
def analyzer(str)
  Integer(str)
  true
rescue ArgumentError
  false
end


363:359
06/09/20 01:36:19
ありがとうございます。組込み関数のInteger(str)は見落としていました。
str.to_i()が例外を投げない仕様になっていたので困っていた所です。
あとリファレンスを読むのが不十分でした。すいません、今後は気を付けます。

364:359
06/09/20 01:37:01
ありがとうございます。組込み関数のInteger(str)は見落としていました。
str.to_i()が例外を投げない仕様になっていたので困っていた所です。
あとリファレンスを読むのが不十分でした。すいません、今後は気を付けます。

365:デフォルトの名無しさん
06/09/25 00:44:03
お礼は一回でおk。

366:デフォルトの名無しさん
06/09/25 05:45:12
ありがdddddddddddddddddddddddddddddddddddddddddddddddd

367:デフォルトの名無しさん
06/10/04 13:58:21
勉強になるので、以前のじゃけんプログラムみたいな数百行程度のプログラムを
また作って欲しいのですが。

368:デフォルトの名無しさん
06/10/04 16:22:36
自分で作った方が勉強になるぞ。


369:デフォルトの名無しさん
06/10/04 19:45:42
>>367
ネタ寄越せ。

370:デフォルトの名無しさん
06/10/04 20:41:08
「ババ抜き」とかどうでしょうか?
表示は、例えばこんな感じで

A:H1 D3 SQ C9 HJ DK S0
B:D4 S0 CQ JK
C:C5 H0 S2 DQ SK
D:D4 H1 CK SJ H7 H9

Aさんが、Bさんから S0 を取りました。

A:H1 D3 SQ C9 HJ DK
B:D4 CQ JK
C:C5 H0 S2 DQ SK
D:D4 H1 CK SJ H7 H9

Bさんが、Cさんから H0 を取りました。

A:H1 D3 SQ C9 HJ DK
B:D4 CQ JK H0
C:C5 S2 DQ SK
D:D4 H1 CK SJ H7 H9

371:デフォルトの名無しさん
06/10/04 23:45:38
たびたびわからなくなるんだが、
引かれた奴が次に他の奴から引くんだっけ?
引いた奴が次に他の奴から引かれるんだっけ?


372:デフォルトの名無しさん
06/10/04 23:52:43
ローカルルールがあるかもしれないが、うちでは引いた奴が他の奴から引かれるというルール。
そうじゃないと、「おい、お前今混ぜてるのはババ引いたからだろ!」ということが起こらず面白くない。

373:デフォルトの名無しさん
06/10/05 23:53:37
最強のジャンケンAI。綿密な先読みで人間などには負けることが無い。


print "ジャンケンしーましょ、最初はグー!"
print "ジャンケン・・・[g=グー/c=チョキ/p=パー]:"
puts "AIの手:"+ ({?g => "パー", ?c => "グー", ?p => "チョキ"}[gets[0]] or raise "死ね。")
puts "お前の負けだ。"

374:デフォルトの名無しさん
06/10/06 00:18:51
>>373
それは後出しと言って反則なんだよ。

375:デフォルトの名無しさん
06/10/06 03:40:29
いや、出す瞬間に、相手の手を見て反応しているのでOK。
ハンターハンターでやってた

376:デフォルトの名無しさん
06/10/06 07:35:01
>>375
ハンターハンターのは「出す直前」だが、>373のは完全に後出し。

377:デフォルトの名無しさん
06/10/06 13:48:43
ババ抜きってさあ、記憶力と観察力があれば、自分のとこから取られたカードがどこにあるかわかるから有利になれるんだけど
そういう戦略を実装できるようにすべき?

378:デフォルトの名無しさん
06/10/06 14:12:53
したけりゃしろよ。
スレ違いだし。

379:デフォルトの名無しさん
06/10/06 15:33:39
スレ違いな理由は何?

380:デフォルトの名無しさん
06/10/06 16:11:05
>>377
した方が面白いと思う。

381:デフォルトの名無しさん
06/10/06 21:14:51
>>377
戦略とかあるの?
ランダムに引く人と戦略を持っている人とで、勝利確率どのぐらい違うが見てみたいね。

382:デフォルトの名無しさん
06/10/06 21:31:05
戦略:こっそりはなくそをつけとく

383:デフォルトの名無しさん
06/10/07 23:40:54
質問です。
次のようなテキストファイルがあったとします。

"ほげほげ","なんとか","むだむだ"
"ほげほ","なんとかか","むだむだだ"
(以下、何十行か続く)

それを

ほげほげ   なんとか   むだむだ
ほげほ   なんとかか   むだむだだ
(以下続く)

という感じの書式(空白はタブです)に変えてテキストファイルとして書き出すスクリプトを書きたいのですが、
正規表現とか難しいことを使わないと行けないのでしょうか。
どなたかやり方ご存じありませんでしょうか。

384:デフォルトの名無しさん
06/10/07 23:49:02
データに","が含まれないなら
while s = gets
puts s.gsub(/"/, "").gsub(/,/, "\t")
end

ちゃんとCSVを処理したいなら、RAAでcsv関連のライブラリを探すとか。

385:デフォルトの名無しさん
06/10/07 23:58:28
>>383 字句解析はrubyに丸投げ
puts eval("[#$_]").join("\t") while gets


386:デフォルトの名無しさん
06/10/08 00:02:31
黒魔術だ・・・

387:デフォルトの名無しさん
06/10/08 00:21:37
>>385
おおー、こんなに簡単にできてしまうんですね。
Rubyって凄い! ありがとうございました!

388:デフォルトの名無しさん
06/10/08 13:58:07
CGIとかで、外部のユーザが自由に入力出来るようなデータに使う場合は、注意しろよー。

389:デフォルトの名無しさん
06/10/08 17:39:10
>>385
ワロタ。
$KCODE忘れんなよー。


390:デフォルトの名無しさん
06/10/17 01:01:11
東京大学教養課程の第一プログラミング言語がRubyに
URLリンク(d.hatena.ne.jp)
URLリンク(b.hatena.ne.jp)

391:デフォルトの名無しさん
06/10/19 06:27:31
東大の宿題予想しようぜ


392:デフォルトの名無しさん
06/10/19 18:29:19
>>391
東大の講師ごくろうさまです。軽くRubyのコンパイラでも作らせてあげてください。


393:デフォルトの名無しさん
06/10/19 20:46:33
そもそも東大生でこんなところに質問しにくるアホはいねーだろ
# と思いたいなあ


394:デフォルトの名無しさん
06/10/19 20:58:36
東大生といえども所詮、学生だし。

395:デフォルトの名無しさん
06/10/19 21:13:49
むしろ東大生がやるレベルの宿題ってのをみてみたいので、
ここに投げてほしいと思う俺がいる。

396:デフォルトの名無しさん
06/10/19 21:40:50
俺も俺も

397:デフォルトの名無しさん
06/10/20 15:12:50
俺もw

398:デフォルトの名無しさん
06/10/20 16:13:56
ほれ
1 2 3 4 5 6 7 8 9
-----------------------------
1| 1 2 3 4 5 6 7 8 9
2| 2 4 6 8 10 12 14 16 18
3| 3 6 9 12 15 18 21 24 27
4| 4 8 12 16 20 24 28 32 36
5| 5 10 15 20 25 30 35 40 45
6| 6 12 18 24 30 36 42 48 54
7| 7 14 21 28 35 42 49 56 63
8| 8 16 24 32 40 48 56 64 72
9| 9 18 27 36 45 54 63 72 81


399:デフォルトの名無しさん
06/10/20 16:27:23
>>398
ずれててよくわかんない。><

400:デフォルトの名無しさん
06/10/20 19:06:04
等幅でおk

401:デフォルトの名無しさん
06/10/22 04:13:34
宿題じゃないけど、聞いていい?

問、重複行を削除せよ

402:デフォルトの名無しさん
06/10/22 04:27:37
ruby -e 'File.open("file.txt"){|f| f.readlines.sort!.uniq! }'

403:デフォルトの名無しさん
06/10/22 06:46:39
>>402
ソートしないでという条件をつけさしてください。


404:デフォルトの名無しさん
06/10/22 07:06:05
temp = ""
ARGF.each_line do |line|
puts line if not line == temp
temp = line
end

405:デフォルトの名無しさん
06/10/22 10:51:00
>>403
print readlines.uniq!

406:デフォルトの名無しさん
06/10/22 11:37:44
uniqって、重複なかったら、nilが帰ってくるんだけど orz

407:デフォルトの名無しさん
06/10/22 11:40:35
print readlines.uniq

で、いけますね。

408:デフォルトの名無しさん
06/10/22 12:12:44
puts ARGF.map.uniq
意味もなく最短を狙ってみる。

409:デフォルトの名無しさん
06/10/22 12:40:15
CodeGolfかよw

410:デフォルトの名無しさん
06/10/22 16:53:55
>>408
ARGFは$<で代用可能。ついでにそのおかげで空白も除去できる。
puts$<.map.uniq

411:デフォルトの名無しさん
06/10/22 22:46:08
>>410
> ついでにそのおかげで空白も除去できる。
将来もずっとそうかわからんぞ。
namespaceの話もあるからな。


412:デフォルトの名無しさん
06/10/23 20:20:24
>411
それを言ったら Ruby なんて教祖の暴走がある限り
ほぼ全ての仕様が将来もずっとそうか分からんぞ。

413:デフォルトの名無しさん
06/10/24 14:38:13
俺はいつもこんな感じ。適宜digest使ったり。

h = []
ARGF.each_line do |line|
puts line if h[$_.sum] =|| 0
end

414:デフォルトの名無しさん
06/10/25 02:02:20
そりゃsyntax errorだと思うが。

if h[line.sum] ||= 0
だとしても常に真だし。

415:デフォルトの名無しさん
06/10/25 14:52:15
質問です。

行列A Matrix[[1, 1, 0, 0], [0, 1, 0, 0], [0, 1, 0, 1], [0, 0, 0, 1], [0, 0, 1, 0], [1, 0, 0, 0]]と
行列B Matrix[[0, 0, 0, 1], [0, 1, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1], [0, 0, 1, 0], [1, 0, 0, 0]]
について、同一座標の数値ごとに論理和をとって行列Cを返すプログラムを教えてください。

この場合行列Cは、Matrix[[0, 0, 0, 0], [0, 1, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1], [0, 0, 1, 0], [1, 0, 0, 0]]
になります。

よろしくお願いします。


416:デフォルトの名無しさん
06/10/25 15:53:48
論理和とったら
[[1, 1, 0, 1], [0, 1, 0, 0], [0, 1, 0, 1], [0, 0, 0, 1], [0, 0, 1, 0], [1, 0, 0, 0]]
にならないか?

a = [[1, 1, 0, 0], [0, 1, 0, 0], [0, 1, 0, 1], [0, 0, 0, 1], [0, 0, 1, 0], [1, 0, 0, 0]]
b = [[0, 0, 0, 1], [0, 1, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1], [0, 0, 1, 0], [1, 0, 0, 0]]
i = -1
puts a.map{|x| x.map{|y| i+=1; y | b.flatten[i]; }}.inspect


417:デフォルトの名無しさん
06/10/25 16:03:33
>>416
ありがとうございます。
論理和というか、両方1のときは1、それ以外は0になる形です。

418:デフォルトの名無しさん
06/10/25 16:25:42
それは、論理積じゃねーの。

419:デフォルトの名無しさん
06/10/25 16:37:23
うむ

420:デフォルトの名無しさん
06/10/25 18:22:22
すいません。その通りです。
論理積でお願いします。

421:416
06/10/25 18:54:17
あとは自分で考えろよ

422:デフォルトの名無しさん
06/10/25 19:59:41
いっぱいある縦棒のどれかをアンパサンドに変えればいいんでないの?

423:デフォルトの名無しさん
06/10/25 20:14:23
puts a.map{|x| x.map{|y| i+=1; y | b.fアンパサンドatten[i]; }}.inspect

こうですか? わかりません!

424:415
06/10/25 21:20:16
おかげさまでできました。
>>416さんをはじめ、このスレのみなさん本当にありがとうございました。

425:デフォルトの名無しさん
06/12/16 19:10:09
Code Golf はここでよいですよね?

数字を与えられて、それを1から配列数までを網羅した配列を短く書く方法はないですか?
例: 9 -> [1, 2, 3, 4, 5, 6, 7, 8, 9]


a = []; 9.times{|i| a += [(i + 1)]}; p a
かな?

426:デフォルトの名無しさん
06/12/16 19:10:59
a = []; 9.times{|i| a << i + 1}; p a

427:デフォルトの名無しさん
06/12/16 19:12:56
あ、これでいいのか・・・
p Array.new(9){|i| i + 1}

428:デフォルトの名無しさん
06/12/16 20:08:27
(1..9).to_a

429:デフォルトの名無しさん
06/12/16 20:10:02
(1..9).map
このほうが短いな

430:デフォルトの名無しさん
06/12/17 00:55:11
Range#to_aが真っ先に思いつくのが普通だよな。

431:デフォルトの名無しさん
06/12/17 01:19:25
[*1..9]

432:デフォルトの名無しさん
06/12/17 07:24:23
>>428-429
マジスカ((((*´ー`)

>>431
これ、知らんかった!
!説明plz
マニュアルに書いてある?

433:デフォルトの名無しさん
06/12/17 10:04:55
>>432
「2.8 *がついた引数は何ですか」

434:デフォルトの名無しさん
06/12/17 11:43:34
>>433
URLリンク(www.ruby-lang.org)
これか・・・。

引数以外にもつけられるんだ

435:デフォルトの名無しさん
06/12/19 23:18:17
>>429
1.9ではEnumerable::Enumeratorが返る。


436:デフォルトの名無しさん
06/12/20 18:32:40
>>435
将来もずっとそうかわからんぞ。

437:デフォルトの名無しさん
06/12/20 22:37:07
>>436
いままでで切り捨てられたものの例を挙げてみてくれないか?


438:デフォルトの名無しさん
06/12/20 22:51:18
なんでなんで

439:デフォルトの名無しさん
06/12/21 09:51:30
警告出るのはあったな

440:デフォルトの名無しさん
06/12/25 18:15:30
<panda>kuma</panda>という文字列を<panda>kum<a></panda>としたいのですが、
gsub('a','<a>')とすると当然ながら<p<a>nd<a>>kum<a></p<a>nd<a>>となってしまいます。

<>の中のaを回避して置換するよい方法ありませんか?

441:デフォルトの名無しさん
06/12/25 19:59:15
<kuma>panda</kuma>

<kuma>p<a>nd<a></kuma>

こう?


442:デフォルトの名無しさん
06/12/25 21:23:23
"<panda>kuma</panda>".scan(/(<.*?>|[^<]+)/).map{|s,*| if /^</ !~ s then s.gsub(/a/, "<a>") else s end }.join
=> "<panda>kum<a></panda>"
"<kuma>panda</kuma>".scan(/(<.*?>|[^<]+)/).map{|s,*| if /^</ !~ s then s.gsub(/a/, "<a>") else s end }.join
=> "<kuma>p<a>nd<a></kuma>"


443:デフォルトの名無しさん
06/12/26 08:38:57
  |s,*|
これ↑をすると、配列がはずれて文字列だけになるんだ。
何故?

444:デフォルトの名無しさん
06/12/26 09:50:48
Ruby では、ブロック引数に値を渡すときの操作は実質的には(多重)代入と同じ。
|s, a| と書くのは、 |s, a| = each_elementのように値が入るのと等価になっている。

また、
a, *b = [1, 2, 3]

とすればaに1、bに[2,3]が入るという規則を思い出すと、今回のケースでは、
「多重代入で最初のものだけを得たい」というケースであるから、
|s, *dummy| と書けば s に最初の要素が、 dummy に残りの配列が手に入る
ことになる。

でも今回は dummy は使わないから省きたい。で、こういう要求にこたえて最
近のRubyでは*パートの変数名を省略できるようになっている。つまり、
a, * = [1, 2, 3]
と書くと a に1が入るという操作になる。

というわけで、ブロック引数に |s, *| と書くと、 s に最初の要素が入ることになる。

ちなみに ,* が省かれるとふつうの代入と区別できないため、sには配列が入る。


……なんだけど実際には * はなくても良いのを思い出した。
カンマがあれば良いので |s,| で良かったです。すまん。


445:デフォルトの名無しさん
06/12/26 12:27:10
>>444
丁寧な説明、サンクス。
なるほど、配列の第1要素のみ利用するってこってですね。

446:デフォルトの名無しさん
06/12/26 21:05:25
car?

447:デフォルトの名無しさん
07/01/05 13:35:21
>446
lispのcar関数とはまた別モノだろ

448:デフォルトの名無しさん
07/01/11 20:52:38
C言語で、値の入れ替えは、以下のように書くことができるようですが、
rubyでもっと短くかけないですか?
a=(a^=b,b^=a,a^b);

449:デフォルトの名無しさん
07/01/11 20:59:26
>>448
a, b = b, a

Cでもいまどきそんなの使うやついねーよ

450:デフォルトの名無しさん
07/01/11 22:47:27
>>449
多値使うのかー。

> Cでもいまどきそんなの使うやついねーよ
そうなのかw

451:デフォルトの名無しさん
07/01/12 14:47:00
自分もできない課題があって困ってるんだが・・・。
りんご本からいくつか課題出されて、その中の

テキスト65ページ 「耳の遠いおばあちゃん」に取り組みなさい。
耳の遠いおばあちゃんのプログラムを書いてみましょう。
おばあちゃんに何を言っても(何をタイプしても)、叫ばない限り(つまり、すべて大文字でタイプしない限り)、
 は?! もっと大きな声で話しておくれ、坊や!
と返事をします。もし叫んだときは、彼女はあなたの言葉を聞いて(少なくとも聞いた気がして)、
 いやー、1938年以来ないねー!
と大声で返事します。
プログラムに真実味を持たせるため、1930から1950のランダムな数字で毎回違う年を叫ぶようにしましょう。
あなたは、BYEと叫ぶまでおばあちゃんとの会話から逃れられません。
う年を叫ぶようにしましょう。
あなたは、BYEと叫ぶまでおばあちゃんとの会話から逃れられません。

とかいうの。

452:デフォルトの名無しさん
07/01/12 20:30:26
>>451
ぐぐれば解答例あるよ。

453:デフォルトの名無しさん
07/01/12 22:54:56
初心者の過去スレ人多すぎで見れない…
どこをググれば??

454:デフォルトの名無しさん
07/01/13 11:11:22
Google以外どこをぐぐるんですか?

loop do
  str = STDIN.gets
  if str.upcase == str
    if 'BYE' == str
      break
    else
      # そうかい。1953年以来ないね〜。
    end
  else
      # はぁあああああ!!!?なんだってぇえぇぇぇぇぇぇーーーーー!!!!
  end
end

動かしてないけど大体こんな感じでしょう。
ちゃんと手を動かしながら本読んでれば出来るハズなんだけどなぁ

455:デフォルトの名無しさん
07/01/14 00:45:45
ぐぐっても解答例が探せなかったorz
そのプログラムも動いてくれなかったです。

乱数のとこで引っかかったりwhileで引っかかったりで前に進みません。

456:デフォルトの名無しさん
07/01/14 01:35:46
454は答えそのものじゃなくて基本的なアプローチ部分のコード例だよ。残りを埋めなきゃ答えにはならん。
それすら見てもわからんのか……。

ところでmixiで質問してるのと同じ人?


457:デフォルトの名無しさん
07/01/14 02:23:57
>>455
何がどうダメなのか説明しないと誰もアドバイスできませんよ。
プログラムを動かそうとしたらエラーが出るなら、
そのエラーメッセージとソースコードをコピペする。

「エスパー募集中ですか?」って言われちゃいますよ?


458:デフォルトの名無しさん
07/01/14 03:11:56
つーか自分で作って詰まれ
どうせ他人の見ても何がどうなってるのかわからんのだろ

確かにこのスレは宿題丸投げも可だが、あまり身勝手におイタしてると
「完全に動作するがコードが面妖で提出不可」なプログラムだけ回答に出されて放置されたりするぞ

459:デフォルトの名無しさん
07/01/14 03:27:05
「ここまでは書けたけどあとはさっぱりです」とか素直に見せられたほうが答返ってくるよな。

460:デフォルトの名無しさん
07/01/14 09:55:57
そして誰かが3行程度で作ってしまう。

461:デフォルトの名無しさん
07/01/14 11:25:50
CodeGolf形式で聞けば答えてくれるぞ

462:デフォルトの名無しさん
07/01/14 22:24:50
俺なら70byteで解く

463:デフォルトの名無しさん
07/01/15 14:23:44
人工無能を作るスレがあるからそっちで聞け


464:デフォルトの名無しさん
07/01/15 22:27:13
関係ない他のスレに迷惑かけちゃいかんよ

465:939
07/01/19 23:12:14
ヒープを配列で実装しろという問題とヒープソートの作り方を教えてください

466:デフォルトの名無しさん
07/01/20 04:09:57
URLリンク(www.geocities.jp)

467:デフォルトの名無しさん
07/01/24 16:36:01
0点の紙が1枚、1点の紙が2枚、4点の紙が1枚入っている箱がある。
この箱から1枚引いて箱に戻すのを6回繰り返したとき、合計点数のとりうる値を求めるプログラムを書け。

この問題の解法を教えてください。よろしくお願いします。



468:デフォルトの名無しさん
07/01/24 19:05:18
>>467
算数の問題が解けないのか、解けるけどRubyに書き直せないのかどっちだ?
# 前者のような気はするけど。


469:デフォルトの名無しさん
07/01/24 20:53:01
>>468
後者です。
場合わけなどを効率よくプログラミングにおとすにはどうしたよいかわかりません。

470:デフォルトの名無しさん
07/01/24 21:42:44
なるほど。アルゴリズムは考え付いたわけね。
じゃ、日本語で良いのでそのアルゴリズムを書いてみて。
それをコード化してあげる。



471:デフォルトの名無しさん
07/01/24 22:00:26
>>467
少年よ、再帰を抱け!

def sum(n,s,k)
ls = [0,1,4]
if n == 0 then
print k,"\t","sum=",s,"\n"
else
for i in 0..2
sum(n-1,s+ls[i],k+[i])
end
end
end

sum(6,0,[])


472:デフォルトの名無しさん
07/01/24 22:00:33
>>470
計算問題として解くなら手計算でゴリ押しできるのですがうまいアルゴリズムが思いつかなくて。
とりあえず0,1,4からなる6個の数字をすべての場合を網羅するように作成して現れる合計値をすべて記録すれば答えはでるんですが、それだと面倒なので質問しました。


473:デフォルトの名無しさん
07/01/24 22:07:57
トリッキーなコード
   ↓

474:デフォルトの名無しさん
07/01/24 22:12:02
>>471
ありがとうございます。
こんなに短くできるんですね。

475:デフォルトの名無しさん
07/01/24 22:19:38
>>473
動的計画法を使う典型問題だね。
b = [0]
6.times{b=[0,1,4].inject(b){|c,y|c + b.map{|x|x+y}}.sort.uniq}
puts b

476:デフォルトの名無しさん
07/01/24 22:24:06
inject([])の間違いだた。まぁ今回はたまたまうまく動くけど。

477:デフォルトの名無しさん
07/01/24 22:33:39
おりゃ
puts (0...6).inject([0]){|b,_|[0,1,4].map{|y|b.map{|x|x+y}}.flatten.sort.uniq}


478:デフォルトの名無しさん
07/01/24 23:08:30
ありがとうございます。この問題の回答としては>>475->>477さんのほうが良いですね。


479:デフォルトの名無しさん
07/01/28 11:47:43
codegolf的に、配列を圧縮する方法ってないでしょうか。

a = [123, 567, 23, 456, 34, 12]


文字列か何かであらわせないかと。
base64でも使うのかな?

480:デフォルトの名無しさん
07/01/28 12:16:22
d=[777,666,555,444,333,222,111,0,123,456,789,12,45,67,89,10]
require 'base64'
require 'zlib'
p d
p pk = d.pack("S*")
p z = Zlib::Deflate.deflate(pk)
p b64 = Base64.encode64(z)

p unb64 = Base64.decode64(b64)
p Zlib::Inflate.inflate(unb64)
p ud = unb64.unpack("S*")

puts "d==ud = "+ (d==ud).to_s
puts "b64.length=" + b64.length.to_s

やってみたのですが、
元に戻らない・・・


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

4664日前に更新/173 KB
担当:undef