探検
なあ、再帰関数好きな人いる? パート3 [転載禁止]©2ch.net
1デフォルトの名無しさん
2015/11/28(土) 18:51:38.86ID:Rc2MJzM/ なあ、再帰関数好きな人いる?
2015/11/29(日) 00:02:43.51ID:aMnBRPWz
>>25
関数型言語は変数再代入禁止(のものが多い)から、そもそもループは書けないんだよね
関数型言語は変数再代入禁止(のものが多い)から、そもそもループは書けないんだよね
34デフォルトの名無しさん
2015/11/29(日) 00:04:00.34ID:BjpFnvXY35デフォルトの名無しさん
2015/11/29(日) 00:06:31.94ID:BjpFnvXY あ、意味は「お遊び感覚で動くものを作るな」という事です。
2015/11/29(日) 00:10:17.71ID:aMnBRPWz
動くんならいいんじゃないの?
2015/11/29(日) 00:20:09.59ID:iZIE7tB6
ま〜た関数型コンプレックスのアホが暴れてるのか
2015/11/29(日) 00:24:10.72ID:aMnBRPWz
関数型は関数脳にならないと書けないからねー
手続き脳がしみついてると貶す対象にしかならないよね
手続き脳がしみついてると貶す対象にしかならないよね
39デフォルトの名無しさん
2015/11/29(日) 00:29:56.09ID:BjpFnvXY お前ら俺を笑い死にさせる気かw
2015/11/29(日) 03:56:07.52ID:1KywF+Vz
初めて知った時すごいと思いました
41uy ◆Qawu9.2l1E
2015/11/29(日) 04:26:32.10ID:RQPUWZLH せっかく埋め立てたのに何またスレ立ててんのゴミクズ
2015/11/29(日) 06:56:51.27ID:GeZFA4k5
ぼくたん初心者なのでわからんけど僕が今作ってる
関数から値を求める計算プログラムで再起型関数が大活躍してるお
たぶん今僕がやってる書き方が一番きれいだと思うんだけどなー
関数から値を求める計算プログラムで再起型関数が大活躍してるお
たぶん今僕がやってる書き方が一番きれいだと思うんだけどなー
2015/11/29(日) 15:21:16.51ID:+8PPW4GA
> たぶん今僕がやってる書き方が一番きれいだと思うんだけどなー
いろんな方法で書いてみないと比較できないんじゃね?
いろんな方法で書いてみないと比較できないんじゃね?
2015/11/29(日) 15:49:46.72ID:BHpn4xqB
クイックソートで再帰なんてありえんと
さんざん言われ続けているのに、まだバカが湧いとるんだな。
ライブラリのループ版を使えば何の手間もかからず高速処理ができるのに
わざわざ問題ありまくりの再帰で書くなんてテロ同然の暴挙。
さんざん言われ続けているのに、まだバカが湧いとるんだな。
ライブラリのループ版を使えば何の手間もかからず高速処理ができるのに
わざわざ問題ありまくりの再帰で書くなんてテロ同然の暴挙。
45デフォルトの名無しさん
2015/11/29(日) 16:17:12.78ID:1uX74bCE2015/11/29(日) 16:52:01.83ID:+8PPW4GA
もうソーティングの話は良いよ、仕事で使う大抵の言語ではライブラリとして用意されてるんだから。
2015/11/29(日) 17:09:26.93ID:BHpn4xqB
>>45
再帰じゃあ、10件程度のソートに控えるという事なんだよな。
再帰じゃあ、10件程度のソートに控えるという事なんだよな。
2015/11/29(日) 17:29:39.96ID:+8PPW4GA
10件程度のソートならソーティングネットワークによるソーティングが一番速いから
十分少ない要素数に対してはそいつを呼び出して終わりだろ。
書いてないだけだろうけど。
十分少ない要素数に対してはそいつを呼び出して終わりだろ。
書いてないだけだろうけど。
49デフォルトの名無しさん
2015/11/29(日) 20:46:37.54ID:ILoya83o >>9
俺の見解では、ツリートラバースに再帰を必要とするのはデータ構造に問題があると思うんだよな。
イテレータの実装を考えると再帰はちょっと無理があるんじゃないかと思う。
もちろん出来ないわけではないのだが。
ノードが子ノードを保持するような原始的なデータ構造は良くないのではないか。
俺の見解では、ツリートラバースに再帰を必要とするのはデータ構造に問題があると思うんだよな。
イテレータの実装を考えると再帰はちょっと無理があるんじゃないかと思う。
もちろん出来ないわけではないのだが。
ノードが子ノードを保持するような原始的なデータ構造は良くないのではないか。
50デフォルトの名無しさん
2015/11/29(日) 20:56:36.78ID:ILoya83o 代表的なツリーの一つとしてHTMLがある。
HTMLのフラグメントを切り出し、別のノードの子として加えるような操作を考えるとき、
これはやはりループに軍配が上がると思う。
もちろん、ノードに子ノードを保持するような原始的なデータ構造ではかなりメンドクサイ。
というのもHTMLの一部を切り出す時、ノードの種類によって、ノードの分割や併合が起こる。
再帰と原始的なデータ構造では非常にめんどくさい。
私はこの用途のために直列化ツリー構造というデータ構造を考案した。
(おそらくすでに一般的に使われているとは思うのだが。)
HTMLのフラグメントを切り出し、別のノードの子として加えるような操作を考えるとき、
これはやはりループに軍配が上がると思う。
もちろん、ノードに子ノードを保持するような原始的なデータ構造ではかなりメンドクサイ。
というのもHTMLの一部を切り出す時、ノードの種類によって、ノードの分割や併合が起こる。
再帰と原始的なデータ構造では非常にめんどくさい。
私はこの用途のために直列化ツリー構造というデータ構造を考案した。
(おそらくすでに一般的に使われているとは思うのだが。)
2015/11/29(日) 21:13:17.76ID:TqJ6Jff5
ループは再帰の特別なケースに過ぎない
ループの方が無駄がなく見える事もあるだろう
だが結局はその程度の話だ
ループの方が無駄がなく見える事もあるだろう
だが結局はその程度の話だ
2015/11/29(日) 21:25:34.60ID:+8PPW4GA
>>49
> イテレータの実装を考えると再帰はちょっと無理があるんじゃないかと思う。
問題はデータ構造の方じゃなくて言語の方だと思う。
というのも、yieldを持つ言語なら再帰を使ったやり方が最も簡潔に書けるから。
-- language:lua
function traverse(node)
if node then
traverse(node.left)
coroutine.yield(node.value)
traverse(node.right)
end
end
co = coroutine.create(traverse)
not_end, value = coroutine.resume(co, node)
> イテレータの実装を考えると再帰はちょっと無理があるんじゃないかと思う。
問題はデータ構造の方じゃなくて言語の方だと思う。
というのも、yieldを持つ言語なら再帰を使ったやり方が最も簡潔に書けるから。
-- language:lua
function traverse(node)
if node then
traverse(node.left)
coroutine.yield(node.value)
traverse(node.right)
end
end
co = coroutine.create(traverse)
not_end, value = coroutine.resume(co, node)
53デフォルトの名無しさん
2015/11/29(日) 21:52:31.69ID:ILoya83o >>52
ちょっとそのやり方で、HTMLの一部をコピペするコード書いてみて。
ちょっとそのやり方で、HTMLの一部をコピペするコード書いてみて。
2015/11/29(日) 22:12:36.39ID:+8PPW4GA
2015/11/29(日) 22:23:46.56ID:euqwPPlR
どういう風に探すか後から指定できる感じで。
56デフォルトの名無しさん
2015/11/29(日) 23:04:51.51ID:ILoya83o57デフォルトの名無しさん
2015/11/29(日) 23:13:29.23ID:ILoya83o HTMLをユーザーの直観に適合する形で操作するのは意外と難しいですよ。
HTMLフラグメントの移動なんてどうですかね。
面白い題材だと思うのですが。
HTMLフラグメントの移動なんてどうですかね。
面白い題材だと思うのですが。
2015/11/29(日) 23:27:31.14ID:euqwPPlR
直列化ツリー構造kwsk
2015/11/30(月) 00:13:02.74ID:vNB8BIt6
2015/11/30(月) 11:10:04.73ID:lmaKmArc
>>59 乙
2015/11/30(月) 14:51:10.36ID:+Ls/PK0X
>>52>>53を繰り返しで書ける人はいないみたいだね。
2015/11/30(月) 20:27:21.92ID:lmaKmArc
そういやC++のstd::mapのイテレータとかってどうなってんるのん?
2015/11/30(月) 21:11:57.14ID:9VRs5I4S
2015/12/01(火) 00:02:40.17ID:M545w8lo
赤黒木って難しいよね、結構。
2015/12/01(火) 13:24:08.38ID:wfTLHpyu
データを吐き出す方法として前方イテレートしかしないの前提ならB+木がループでトラバース出来る上に高速なんだけど
挿入と削除を頻繁にするなら、そしてデータがキャッシュに乗り切らない程度に沢山あるなら赤黒木が高速になる
全部キャッシュに乗る程度の小さなデータ数ならAVL木が高速で
更に小さいならベクタ上にヒープ木でも作ればって話になる。
どの構造でも再帰で列挙出来るけど、ループでAVL木や赤黒木のデータを列挙するのは骨だな
挿入と削除を頻繁にするなら、そしてデータがキャッシュに乗り切らない程度に沢山あるなら赤黒木が高速になる
全部キャッシュに乗る程度の小さなデータ数ならAVL木が高速で
更に小さいならベクタ上にヒープ木でも作ればって話になる。
どの構造でも再帰で列挙出来るけど、ループでAVL木や赤黒木のデータを列挙するのは骨だな
66uy ◆Qawu9.2l1E
2015/12/01(火) 15:00:00.16ID:p3g6QuXB 再帰・ループの相互変換が難しいとかさあ
アルゴリズムの根本的なところ理解してないだけ
恥ずかしすぎるこのスレ
アルゴリズムの根本的なところ理解してないだけ
恥ずかしすぎるこのスレ
2015/12/01(火) 16:04:55.52ID:M545w8lo
f(0,b)=b+1
f(a,0)=f(a-1,1)
f(a,b)=f(a-1,f(a,b-1))
f(a,0)=f(a-1,1)
f(a,b)=f(a-1,f(a,b-1))
2015/12/01(火) 16:39:12.55ID:wfTLHpyu
69uy ◆Qawu9.2l1E
2015/12/01(火) 17:10:17.46ID:p3g6QuXB rubyで書いてくれないとちょっと。
2015/12/01(火) 17:22:48.32ID:wfTLHpyu
2015/12/01(火) 17:26:42.78ID:alJpKlDN
2015/12/01(火) 17:26:51.00ID:UT6gApH3
uyって式も読めないのかな
2015/12/01(火) 17:39:29.54ID:UT6gApH3
>>73
uyの残した名言
何で出来ているか?というのは愚問過ぎる
例えばそれを「uy」としましょう
「uy」から派性したAやBといった概念から「uy」を辿る事は出来る
例えばこの世界にある「オブジェクト指向」という概念や「量子ビット」といった概念から
「uy」を辿る事が可能なので、
それらで世界が出来ているといった勘違いが可能なのです
でもそれは、一体いくつ「uy」から継承がネストしていて、プログラム等でいえばメソッドが追加されてしまった純粋性のない概念なのでしょうか?
それを知っているのは「uy」だけです
この世界にあるすべての概念は「uy」へと通じているので、
料理人は料理を通じて世界を知り、スポーツ選手はスポーツを通じて世界を知ります
誰も「uy」からは逃げられないんだよ
uyの残した名言
何で出来ているか?というのは愚問過ぎる
例えばそれを「uy」としましょう
「uy」から派性したAやBといった概念から「uy」を辿る事は出来る
例えばこの世界にある「オブジェクト指向」という概念や「量子ビット」といった概念から
「uy」を辿る事が可能なので、
それらで世界が出来ているといった勘違いが可能なのです
でもそれは、一体いくつ「uy」から継承がネストしていて、プログラム等でいえばメソッドが追加されてしまった純粋性のない概念なのでしょうか?
それを知っているのは「uy」だけです
この世界にあるすべての概念は「uy」へと通じているので、
料理人は料理を通じて世界を知り、スポーツ選手はスポーツを通じて世界を知ります
誰も「uy」からは逃げられないんだよ
あぁ、俺がuyと同一人物だと勘違いされたのではなく、
uyって人がそういう名言を残したって話か
ごめんごめん
uyって人がそういう名言を残したって話か
ごめんごめん
2015/12/01(火) 18:38:14.45ID:UT6gApH3
誰も uy なんかに価値を求めてないのにね
2015/12/01(火) 18:56:25.56ID:wfTLHpyu
でかでかと引用した奴が言うと説得力があるね。
2015/12/01(火) 19:16:25.46ID:UT6gApH3
んでuyちゃんのループ問題はまだ解決しないのかしら
2015/12/01(火) 19:43:22.28ID:M545w8lo
まさにuyがアルゴリズムの根本的なところを理解しているかどうか問われているなw
2015/12/01(火) 19:54:09.54ID:UT6gApH3
それな、今までC++スレ読んでてこいつ頭おかしいなとは思ってたけど実力が問われるよな
2015/12/01(火) 19:58:37.14ID:wfTLHpyu
はてさてuyの実力は如何。
# 俺自身の実力はさておき。
# 俺自身の実力はさておき。
2015/12/01(火) 20:19:08.98ID:UT6gApH3
おせぇな uy
2015/12/01(火) 20:49:22.02ID:M545w8lo
uy自力で頑張ってんのか?
なかなか根性あるじゃないか。
俺ならググって解答見てしまうがw
なかなか根性あるじゃないか。
俺ならググって解答見てしまうがw
再帰で書かれた超有名な関数をループにするだけの簡単なお仕事なのに
何ですぐに出来ないんだろうね?
# 全然簡単じゃないからです
何ですぐに出来ないんだろうね?
# 全然簡単じゃないからです
2015/12/02(水) 02:08:55.48ID:sE+ivAhG
末尾再帰に書き換えてから蓄積引数を中に押し込んでループにするんだよ。
やり方を書いたのだからきっとuyにもできるはず!
やり方を書いたのだからきっとuyにもできるはず!
2015/12/02(水) 06:47:05.05ID:UkYZlpUx
2015/12/02(水) 08:22:03.59ID:73uUfhWJ
スタックだろ。
再帰とループ+スタックは等価。
理屈ではそうだが実際やるのは結構難しいんじゃね。
再帰とループ+スタックは等価。
理屈ではそうだが実際やるのは結構難しいんじゃね。
89uy ◆Qawu9.2l1E
2015/12/02(水) 08:50:25.92ID:znqtbEKc >>70
http://ideone.com/KDSDTc
「この程度」が難しいとか言われても
は? としか思えない
再帰というのは単なるスタック付きのループであって
君たちがどこら辺で躓いているのか理解できないんです
やっぱわからない所がわからない状態なんだろうけど、
つうかSTACKUって知っていますか?
http://ideone.com/KDSDTc
「この程度」が難しいとか言われても
は? としか思えない
再帰というのは単なるスタック付きのループであって
君たちがどこら辺で躓いているのか理解できないんです
やっぱわからない所がわからない状態なんだろうけど、
つうかSTACKUって知っていますか?
90uy ◆Qawu9.2l1E
2015/12/02(水) 09:14:47.18ID:znqtbEKc ちなみにここ一週間のuyの生活は、朝起きて、ネトゲして朝寝る です。
ちょうどいま、起きたところではなく24時間起き続けていたので今から寝る前でした
とあるゲームであと100戦程の対戦をこなし、誰よりも速く称号を獲得しようとしてる最中です
2chのム板なんて頻繁に開いてる暇とかないし結構忙しいんですわ
ちょうどいま、起きたところではなく24時間起き続けていたので今から寝る前でした
とあるゲームであと100戦程の対戦をこなし、誰よりも速く称号を獲得しようとしてる最中です
2chのム板なんて頻繁に開いてる暇とかないし結構忙しいんですわ
2015/12/02(水) 09:18:01.80ID:UkYZlpUx
>>89
お見事です。申し訳ありませんでした。
お見事です。申し訳ありませんでした。
2015/12/02(水) 09:19:02.13ID:UkYZlpUx
自分には分からなかったわ
じゃあ質問なんだけど、再帰は全てスタック+ループで書き換えられるの?
じゃあ質問なんだけど、再帰は全てスタック+ループで書き換えられるの?
2015/12/02(水) 09:34:55.30ID:UkYZlpUx
連投だけど分かったかも、
再帰で帰ってくるべき値をスタックしておくってことでループ+スタック=再帰なのね
再帰で帰ってくるべき値をスタックしておくってことでループ+スタック=再帰なのね
>>89
問題のすり替えはいけないな。
俺は「難しくないならやってみて?」って言っただけで
そもそも「再帰のほうがループより圧倒的に簡潔に書けるよね?」って文脈だろ。
君が「難しいから出来るもんならやってみろ」って捉えたかどうかなんざ知らんがおつかれさん
うんうん、言いたいことは分かった。
それで、そのコードのどこら辺が綺麗なの?
ちなみに機械的に変換したのがこちら(rubyじゃなくてごめんよ)
https://ideone.com/XsZh4c
fとhは機械的に変換したという意味では等価だし君のコードとほぼ同じ事をしてるのだけど、
h関数をパッと見て>>69式と等しいって言うのは凄く度胸が居るよね?
>>92
そもそも再帰をどうやってソフトウェア実装してるかというとコールスタック+ジャンプ≒スタック+ループな訳で
# ちなみにスタックの正しいスペルはstack。stackuなんて子は知りませんね。
問題のすり替えはいけないな。
俺は「難しくないならやってみて?」って言っただけで
そもそも「再帰のほうがループより圧倒的に簡潔に書けるよね?」って文脈だろ。
君が「難しいから出来るもんならやってみろ」って捉えたかどうかなんざ知らんがおつかれさん
うんうん、言いたいことは分かった。
それで、そのコードのどこら辺が綺麗なの?
ちなみに機械的に変換したのがこちら(rubyじゃなくてごめんよ)
https://ideone.com/XsZh4c
fとhは機械的に変換したという意味では等価だし君のコードとほぼ同じ事をしてるのだけど、
h関数をパッと見て>>69式と等しいって言うのは凄く度胸が居るよね?
>>92
そもそも再帰をどうやってソフトウェア実装してるかというとコールスタック+ジャンプ≒スタック+ループな訳で
# ちなみにスタックの正しいスペルはstack。stackuなんて子は知りませんね。
2015/12/02(水) 10:13:14.24ID:amR8vvu9
>>92
数学的に証明されてる。
数学的に証明されてる。
2015/12/02(水) 10:15:05.34ID:UkYZlpUx
2015/12/02(水) 11:13:43.91ID:sE+ivAhG
>>97
アセンブリ言語によくあるcall系命令の挙動を正確に言えるようになれば
どんな再帰もスタックとループで書けるようになるよ
何しろスタックとループで再帰を表現してるのがcall系命令だからね。
それをそのまま書くとこんな具合に超汚くなるけど。
https://ideone.com/0QXd8O
アセンブリ言語によくあるcall系命令の挙動を正確に言えるようになれば
どんな再帰もスタックとループで書けるようになるよ
何しろスタックとループで再帰を表現してるのがcall系命令だからね。
それをそのまま書くとこんな具合に超汚くなるけど。
https://ideone.com/0QXd8O
100デフォルトの名無しさん
2015/12/02(水) 12:52:27.49ID:UkYZlpUx ありがとうございます
101デフォルトの名無しさん
2015/12/02(水) 18:34:40.93ID:73uUfhWJ uyなかなかやるな。
ググって解答見た可能性もあるが、ググれるのも実力のうちだからな。
ググって解答見た可能性もあるが、ググれるのも実力のうちだからな。
102.パンティーガァル
2015/12/02(水) 20:57:19.51ID:V8iEgN6C103デフォルトの名無しさん
2015/12/02(水) 22:54:08.11ID:73uUfhWJ104デフォルトの名無しさん
2015/12/03(木) 13:20:12.94ID:lU1L6vf0 誰かループ版と再帰版でベンチマークしてみなよ
106デフォルトの名無しさん
2015/12/03(木) 17:06:18.36ID:Sp77D/ez >>105
メンドクサイやつだなお前w
メンドクサイやつだなお前w
107デフォルトの名無しさん
2015/12/03(木) 17:30:30.61ID:Sp77D/ez109デフォルトの名無しさん
2015/12/03(木) 18:28:15.45ID:Sp77D/ez111デフォルトの名無しさん
2015/12/03(木) 20:19:17.43ID:Sp77D/ez112デフォルトの名無しさん
2015/12/03(木) 22:49:14.77ID:Sp77D/ez https://ideone.com/hlWWly
んんん、haskell 気持ちいい!
んんん、haskell 気持ちいい!
113デフォルトの名無しさん
2015/12/04(金) 18:59:19.58ID:abMxFNxB きっしょ
114デフォルトの名無しさん
2015/12/04(金) 20:33:45.20ID:tAWNVevx んぎもちいいいいいいいいいい
115デフォルトの名無しさん
2015/12/05(土) 12:06:08.66ID:kPO9yvRD 気持ち悪い生き物だなこいつは
116デフォルトの名無しさん
2015/12/05(土) 12:08:54.94ID:75VGJDuj 再起関数難しくて苦手だわ
117デフォルトの名無しさん
2015/12/05(土) 12:38:44.60ID:vOhmiziG おいらも苦手だわ
118デフォルトの名無しさん
2015/12/05(土) 12:50:09.98ID:fWHJ2v3J アッカーマンを知ったばかりで嬉しくてしょうがないんだろうな
俺くらいになるとどうでもよくなるけど
俺くらいになるとどうでもよくなるけど
119デフォルトの名無しさん
2015/12/05(土) 14:22:16.61ID:3X0n/q/1 さぁ次は竹内関数(たらい回し関数)だ!
120デフォルトの名無しさん
2015/12/05(土) 14:24:24.30ID:FIUesRuL121デフォルトの名無しさん
2015/12/05(土) 16:27:08.57ID:fWHJ2v3J その問題が解けて嬉しかったんだろうな
122デフォルトの名無しさん
2015/12/05(土) 22:53:23.45ID:Ij5oOkBB たらいのループ化と展開の様子誰か頼む
123デフォルトの名無しさん
2015/12/07(月) 01:05:16.16ID:OW/BWl2V なんで自分でやらない?
再帰関数が好きなんだろ?
再帰関数が好きなんだろ?
124ネトuy ◆Qawu9.2l1E
2015/12/07(月) 02:12:06.27ID:IGEuV37f w
125デフォルトの名無しさん
2015/12/07(月) 19:27:26.73ID:NCOmGjcr126デフォルトの名無しさん
2015/12/08(火) 10:04:03.24ID:HiEYAt85 きも
127デフォルトの名無しさん
2015/12/10(木) 22:01:50.93ID:ZuWvmJPo たらいのループ化どうやるかわからん。
128デフォルトの名無しさん
2015/12/10(木) 23:27:19.50ID:ZuWvmJPo んーなんかプログラムカウンタに相当するものをスタックに積まなきゃいけない感じ?
129デフォルトの名無しさん
2015/12/11(金) 02:06:03.72ID:6gh0GR4/130デフォルトの名無しさん
2015/12/11(金) 13:42:03.51ID:Z+QL5bbx 再帰厨はcall命令とjmp命令の違いが分かってから布教してほしい
131デフォルトの名無しさん
2015/12/11(金) 18:14:40.60ID:H0NYZxX+132デフォルトの名無しさん
2015/12/11(金) 18:27:07.72ID:FXKTAEC3 >命令にもこういうのがあるよ、必要だからあるんだよ。
だからどうしたとしか。
基地外宗教を布教するなら、自分でするんだね。
だからどうしたとしか。
基地外宗教を布教するなら、自分でするんだね。
レスを投稿する
ニュース
- 【速報】政府、与党がNISA未成年解禁を検討 ★2 [蚤の市★]
- 【TV】ファン5万人がガチで投票! プロ野球総選挙、栄えある1位は [牛丼★]
- 中国外務省「正式な発言撤回なければ受け入れず」 高市首相は台湾有事「存立危機事態」言及せずも「言及しないことと撤回は別問題」★12 [ぐれ★]
- 【*彡】巨人・坂本勇人 『流れ星に何を願うか』の質問に「結婚相手」と即答、結婚願望告白 女性ファンから歓声と悲鳴 [鉄チーズ烏★]
- 「まだ朝7時に通勤してるんですか?」人気VTuberが語った“働き方への提言”に議論沸騰 [夜のけいちゃん★]
- 【おこめ】ベトナムから密輸のコメを「国産」と偽り販売容疑、ベトナム人ら2人追送検…300トン売って1億3000万円稼いだか 大阪 ★2 [ぐれ★]
