1 名前:RUBY [05/01/24 22:17:37 ] 私は、ある大学の1年生です。今、情報処理の講義でRUBYを習っています。 その講義で、期末テストとして課題が出たのですが、プログラミング初心者の私には 全然歯が立ちません。締め切りは1/31です。プロも皆さんには簡単な 問題かもしれませんがどうか教えてください。 課題は以下の通りです。
348 名前:デフォルトの名無しさん mailto:sage [2006/09/11(月) 16:43:40 ] やっぱり、なにがあれなんだろう。
349 名前:デフォルトの名無しさん mailto:sage [2006/09/11(月) 16:47:04 ] 「数MBのファイルを、わざわざ Ruby の read/write を使ってアップローダ側 のディレクトリの特定のファイルにコピーするのは処理にオーバヘッドがかか るので」 てとこじゃね。
350 名前:デフォルトの名無しさん mailto:sage [2006/09/11(月) 16:51:16 ] ああでもあれか、 FileUtils.cp ってけっきょく ruby レベルで read/write を繰り返しているわけだよな。まあ、当り前だが。 それに、ソースを見てみると file.size の大小で TempFile かどうか判定し てるね。 is_a? とかを使った方がいいんじゃないかなあ。
351 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん [2006/09/15(金) 02:07:28 ] def seach(dir, key) ↑ dir(ディレクトリ), key(検索キーワード) で指定したディレクトリ下にある合致するファイルを検索して 合致するファイル名の配列を返す関数のコードお願いします。
353 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/09/15(金) 04:44:56 ] Dir.glob(dir + "/**/" + key) じゃ駄目?
355 名前:デフォルトの名無しさん mailto:sage [2006/09/15(金) 09:46:53 ] 合致するファイルって名前だけか。
356 名前:デフォルトの名無しさん mailto:sage [2006/09/15(金) 12:35:15 ] 353.gsub(/serch/, 'search')
357 名前:デフォルトの名無しさん mailto:sage [2006/09/15(金) 12:36:53 ] 353.gsub(/seach/, 'search')
358 名前:デフォルトの名無しさん mailto:sage [2006/09/15(金) 13:35:36 ] 353.gsub /(?=。)/, "お" (^ω^ )
359 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:age [2006/09/19(火) 13:54:30 ] age
362 名前:デフォルトの名無しさん mailto:sage [2006/09/20(水) 00:09:54 ] def analyzer(str) Integer(str) true rescue ArgumentError false end
363 名前:359 mailto:sage [2006/09/20(水) 01:36:19 ] ありがとうございます。組込み関数のInteger(str)は見落としていました。 str.to_i()が例外を投げない仕様になっていたので困っていた所です。 あとリファレンスを読むのが不十分でした。すいません、今後は気を付けます。
364 名前:359 mailto:sage [2006/09/20(水) 01:37:01 ] ありがとうございます。組込み関数のInteger(str)は見落としていました。 str.to_i()が例外を投げない仕様になっていたので困っていた所です。 あとリファレンスを読むのが不十分でした。すいません、今後は気を付けます。
365 名前:デフォルトの名無しさん mailto:sage [2006/09/25(月) 00:44:03 ] お礼は一回でおk。
366 名前:デフォルトの名無しさん mailto:sage [2006/09/25(月) 05:45:12 ] ありがdddddddddddddddddddddddddddddddddddddddddddddddd
367 名前:デフォルトの名無しさん mailto:sage [2006/10/04(水) 13:58:21 ] 勉強になるので、以前のじゃけんプログラムみたいな数百行程度のプログラムを また作って欲しいのですが。
368 名前:デフォルトの名無しさん mailto:sage [2006/10/04(水) 16:22:36 ] 自分で作った方が勉強になるぞ。
369 名前:デフォルトの名無しさん mailto:sage [2006/10/04(水) 19:45:42 ] >>367 ネタ寄越せ。
370 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/10/04(水) 23:45:38 ] たびたびわからなくなるんだが、 引かれた奴が次に他の奴から引くんだっけ? 引いた奴が次に他の奴から引かれるんだっけ?
372 名前:デフォルトの名無しさん mailto:sage [2006/10/04(水) 23:52:43 ] ローカルルールがあるかもしれないが、うちでは引いた奴が他の奴から引かれるというルール。 そうじゃないと、「おい、お前今混ぜてるのはババ引いたからだろ!」ということが起こらず面白くない。
373 名前:デフォルトの名無しさん mailto:sage [2006/10/05(木) 23:53:37 ] 最強のジャンケンAI。綿密な先読みで人間などには負けることが無い。 ↓ print "ジャンケンしーましょ、最初はグー!" print "ジャンケン・・・[g=グー/c=チョキ/p=パー]:" puts "AIの手:"+ ({?g => "パー", ?c => "グー", ?p => "チョキ"}[gets[0]] or raise "死ね。") puts "お前の負けだ。"
374 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 00:18:51 ] >>373 それは後出しと言って反則なんだよ。
375 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 03:40:29 ] いや、出す瞬間に、相手の手を見て反応しているのでOK。 ハンターハンターでやってた
376 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 07:35:01 ] >>375 ハンターハンターのは「出す直前」だが、>373のは完全に後出し。
377 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 13:48:43 ] ババ抜きってさあ、記憶力と観察力があれば、自分のとこから取られたカードがどこにあるかわかるから有利になれるんだけど そういう戦略を実装できるようにすべき?
378 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 14:12:53 ] したけりゃしろよ。 スレ違いだし。
379 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 15:33:39 ] スレ違いな理由は何?
380 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 16:11:05 ] >>377 した方が面白いと思う。
381 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 21:14:51 ] >>377 戦略とかあるの? ランダムに引く人と戦略を持っている人とで、勝利確率どのぐらい違うが見てみたいね。
382 名前:デフォルトの名無しさん mailto:sage [2006/10/06(金) 21:31:05 ] 戦略:こっそりはなくそをつけとく
383 名前:デフォルトの名無しさん mailto:sage [2006/10/07(土) 23:40:54 ] 質問です。 次のようなテキストファイルがあったとします。 "ほげほげ","なんとか","むだむだ" "ほげほ","なんとかか","むだむだだ" (以下、何十行か続く) それを ほげほげ なんとか むだむだ ほげほ なんとかか むだむだだ (以下続く) という感じの書式(空白はタブです)に変えてテキストファイルとして書き出すスクリプトを書きたいのですが、 正規表現とか難しいことを使わないと行けないのでしょうか。 どなたかやり方ご存じありませんでしょうか。
384 名前:デフォルトの名無しさん mailto:sage [2006/10/07(土) 23:49:02 ] データに","が含まれないなら while s = gets puts s.gsub(/"/, "").gsub(/,/, "\t") end ちゃんとCSVを処理したいなら、RAAでcsv関連のライブラリを探すとか。
385 名前:デフォルトの名無しさん mailto:sage [2006/10/07(土) 23:58:28 ] >>383 字句解析はrubyに丸投げ puts eval("[#$_]").join("\t") while gets
386 名前:デフォルトの名無しさん mailto:sage [2006/10/08(日) 00:02:31 ] 黒魔術だ・・・
387 名前:デフォルトの名無しさん mailto:sage [2006/10/08(日) 00:21:37 ] >>385 おおー、こんなに簡単にできてしまうんですね。 Rubyって凄い! ありがとうございました!
388 名前:デフォルトの名無しさん mailto:sage [2006/10/08(日) 13:58:07 ] CGIとかで、外部のユーザが自由に入力出来るようなデータに使う場合は、注意しろよー。
389 名前:デフォルトの名無しさん mailto:sage [2006/10/08(日) 17:39:10 ] >>385 ワロタ。 $KCODE忘れんなよー。
390 名前:デフォルトの名無しさん [2006/10/17(火) 01:01:11 ] 東京大学教養課程の第一プログラミング言語がRubyに d.hatena.ne.jp/sumii/20060928/1159394568 b.hatena.ne.jp/entry/http://d.hatena.ne.jp/sumii/20060928/1159394568
391 名前:デフォルトの名無しさん mailto:sage [2006/10/19(木) 06:27:31 ] 東大の宿題予想しようぜ
392 名前:デフォルトの名無しさん mailto:sage [2006/10/19(木) 18:29:19 ] >>391 東大の講師ごくろうさまです。軽くRubyのコンパイラでも作らせてあげてください。
393 名前:デフォルトの名無しさん mailto:sage [2006/10/19(木) 20:46:33 ] そもそも東大生でこんなところに質問しにくるアホはいねーだろ # と思いたいなあ
394 名前:デフォルトの名無しさん mailto:sage [2006/10/19(木) 20:58:36 ] 東大生といえども所詮、学生だし。
395 名前:デフォルトの名無しさん mailto:sage [2006/10/19(木) 21:13:49 ] むしろ東大生がやるレベルの宿題ってのをみてみたいので、 ここに投げてほしいと思う俺がいる。
396 名前:デフォルトの名無しさん mailto:sage [2006/10/19(木) 21:40:50 ] 俺も俺も
397 名前:デフォルトの名無しさん mailto:sage [2006/10/20(金) 15:12:50 ] 俺もw
398 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/10/20(金) 16:27:23 ] >>398 ずれててよくわかんない。><
400 名前:デフォルトの名無しさん mailto:sage [2006/10/20(金) 19:06:04 ] 等幅でおk
401 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 04:13:34 ] 宿題じゃないけど、聞いていい? 問、重複行を削除せよ
402 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 04:27:37 ] ruby -e 'File.open("file.txt"){|f| f.readlines.sort!.uniq! }'
403 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 06:46:39 ] >>402 ソートしないでという条件をつけさしてください。
404 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 07:06:05 ] temp = "" ARGF.each_line do |line| puts line if not line == temp temp = line end
405 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 10:51:00 ] >>403 print readlines.uniq!
406 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 11:37:44 ] uniqって、重複なかったら、nilが帰ってくるんだけど orz
407 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 11:40:35 ] print readlines.uniq で、いけますね。
408 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 12:12:44 ] puts ARGF.map.uniq 意味もなく最短を狙ってみる。
409 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 12:40:15 ] CodeGolfかよw
410 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 16:53:55 ] >>408 ARGFは$<で代用可能。ついでにそのおかげで空白も除去できる。 puts$<.map.uniq
411 名前:デフォルトの名無しさん mailto:sage [2006/10/22(日) 22:46:08 ] >>410 > ついでにそのおかげで空白も除去できる。 将来もずっとそうかわからんぞ。 namespaceの話もあるからな。
412 名前:デフォルトの名無しさん mailto:sage [2006/10/23(月) 20:20:24 ] >411 それを言ったら Ruby なんて教祖の暴走がある限り ほぼ全ての仕様が将来もずっとそうか分からんぞ。
413 名前:デフォルトの名無しさん mailto:sage [2006/10/24(火) 14:38:13 ] 俺はいつもこんな感じ。適宜digest使ったり。 h = [] ARGF.each_line do |line| puts line if h[$_.sum] =|| 0 end
414 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 02:02:20 ] そりゃsyntax errorだと思うが。 if h[line.sum] ||= 0 だとしても常に真だし。
415 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 16:03:33 ] >>416 ありがとうございます。 論理和というか、両方1のときは1、それ以外は0になる形です。
418 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 16:25:42 ] それは、論理積じゃねーの。
419 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 16:37:23 ] うむ
420 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 18:22:22 ] すいません。その通りです。 論理積でお願いします。
421 名前:416 mailto:sage [2006/10/25(水) 18:54:17 ] あとは自分で考えろよ
422 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 19:59:41 ] いっぱいある縦棒のどれかをアンパサンドに変えればいいんでないの?
423 名前:デフォルトの名無しさん mailto:sage [2006/10/25(水) 20:14:23 ] puts a.map{|x| x.map{|y| i+=1; y | b.fアンパサンドatten[i]; }}.inspect こうですか? わかりません!
424 名前:415 mailto:sage [2006/10/25(水) 21:20:16 ] おかげさまでできました。 >>416 さんをはじめ、このスレのみなさん本当にありがとうございました。
425 名前:デフォルトの名無しさん [2006/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 名前:デフォルトの名無しさん [2006/12/16(土) 19:10:59 ] a = []; 9.times{|i| a << i + 1}; p a
427 名前:デフォルトの名無しさん [2006/12/16(土) 19:12:56 ] あ、これでいいのか・・・ p Array.new(9){|i| i + 1}
428 名前:デフォルトの名無しさん mailto:sage [2006/12/16(土) 20:08:27 ] (1..9).to_a
429 名前:デフォルトの名無しさん mailto:sage [2006/12/16(土) 20:10:02 ] (1..9).map このほうが短いな
430 名前:デフォルトの名無しさん mailto:sage [2006/12/17(日) 00:55:11 ] Range#to_aが真っ先に思いつくのが普通だよな。
431 名前:デフォルトの名無しさん mailto:sage [2006/12/17(日) 01:19:25 ] [*1..9]
432 名前:デフォルトの名無しさん [2006/12/17(日) 07:24:23 ] >>428-429 マジスカ((((*´ー`) >>431 これ、知らんかった! !説明plz マニュアルに書いてある?
433 名前:デフォルトの名無しさん mailto:sage [2006/12/17(日) 10:04:55 ] >>432 「2.8 *がついた引数は何ですか」
434 名前:デフォルトの名無しさん [2006/12/17(日) 11:43:34 ] >>433 www.ruby-lang.org/ja/man/index.cgi?cmd=view;name=FAQ::%CA%D1%BF%F4%A1%A2%C4%EA%BF%F4%A1%A2%B0%FA%BF%F4#a2.2e8.20.2a.a4.ac.a4.c4.a4.a4.a4.bf.b0.fa.bf.f4.a4.cf.b2.bf.a4.c7.a4.b9.a4.ab これか・・・。 引数以外にもつけられるんだ
435 名前:デフォルトの名無しさん mailto:sage [2006/12/19(火) 23:18:17 ] >>429 1.9ではEnumerable::Enumeratorが返る。
436 名前:デフォルトの名無しさん mailto:sage [2006/12/20(水) 18:32:40 ] >>435 将来もずっとそうかわからんぞ。
437 名前:デフォルトの名無しさん mailto:sage [2006/12/20(水) 22:37:07 ] >>436 いままでで切り捨てられたものの例を挙げてみてくれないか?
438 名前:デフォルトの名無しさん mailto:sage [2006/12/20(水) 22:51:18 ] なんでなんで
439 名前:デフォルトの名無しさん mailto:sage [2006/12/21(木) 09:51:30 ] 警告出るのはあったな
440 名前:デフォルトの名無しさん [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/12/25(月) 19:59:15 ] <kuma>panda</kuma> ↓ <kuma>p<a>nd<a></kuma> こう?
442 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/12/26(火) 08:38:57 ] |s,*| これ↑をすると、配列がはずれて文字列だけになるんだ。 何故?
444 名前:デフォルトの名無しさん mailto:sage [2006/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 名前:デフォルトの名無しさん mailto:sage [2006/12/26(火) 12:27:10 ] >>444 丁寧な説明、サンクス。 なるほど、配列の第1要素のみ利用するってこってですね。
446 名前:デフォルトの名無しさん mailto:sage [2006/12/26(火) 21:05:25 ] car?
447 名前:デフォルトの名無しさん mailto:sage [2007/01/05(金) 13:35:21 ] >446 lispのcar関数とはまた別モノだろ
448 名前:デフォルトの名無しさん [2007/01/11(木) 20:52:38 ] C言語で、値の入れ替えは、以下のように書くことができるようですが、 rubyでもっと短くかけないですか? a=(a^=b,b^=a,a^b);