[解決済み] Pythonの最大再帰深度とその増やし方とは?
2022-03-17 07:49:34
質問
このような末尾再帰関数があります。
def recursive_function(n, sum):
if n < 1:
return sum
else:
return recursive_function(n-1, sum+n)
c = 998
print(recursive_function(c, 0))
まで動作します。
n=997
を出力します。
RecursionError: maximum recursion depth exceeded in comparison
. これは単なるスタックオーバーフローなのでしょうか?これを回避する方法はあるのでしょうか?
解決方法は?
スタックオーバーフローに対するガードですね。Python(というかCPythonの実装)は末尾再帰を最適化しないので、奔放な再帰はスタックオーバーフローを引き起こします。再帰の上限を確認するには
sys.getrecursionlimit
:
import sys
print(sys.getrecursionlimit())
で再帰の上限を変更します。
sys.setrecursionlimit
:
sys.setrecursionlimit(1500)
標準の制限は少し控えめですが、Pythonのスタックフレームはかなり大きくなる可能性があります。
Pythonは関数型言語ではないので、末尾再帰は特に効率的な手法ではありません。可能であれば、アルゴリズムを繰り返し書き直す方が一般的には良い考えです。
関連
-
opencvとpillowを用いた顔認証システム(デモあり)
-
ピローによる動的キャプチャ認識のためのPythonサンプルコード
-
[解決済み] Pythonで現在時刻を取得する方法
-
[解決済み] Pythonで2つのリストを連結する方法は?
-
[解決済み] Pythonのリストメソッドであるappendとextendの違いは何ですか?
-
[解決済み] 最小限の驚き」と「変更可能なデフォルトの引数
-
[解決済み] パラメータに**(ダブルスター/アスタリスク)、*(スター/アスタリスク)がありますが、これはどういう意味ですか?
-
[解決済み] 末尾再帰とは何ですか?
-
[解決済み】__str__と__repr__の違いは何ですか?
-
[解決済み】Pythonは末尾再帰を最適化するか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Pythonを使って簡単なzipファイルの解凍パスワードを手作業で解く
-
Python入門 openを使ったファイルの読み書きの方法
-
[解決済み】TypeError: unhashable type: 'numpy.ndarray'.
-
[解決済み] データ型が理解できない
-
[解決済み】OSError: [WinError 193] %1 は有効な Win32 アプリケーションではありません。
-
[解決済み】csv.Error:イテレータはバイトではなく文字列を返すべき
-
[解決済み] 'DataFrame' オブジェクトに 'sort' 属性がない
-
[解決済み】LogisticRegression: Pythonでsklearnを使用して、未知のラベルタイプ: '連続'を使用しています。
-
[解決済み】ValueError: xとyは同じサイズでなければならない
-
[解決済み] Pythonで再帰?RuntimeError: Pythonオブジェクトの呼び出し中に最大再帰深度を超えました [重複] RuntimeError: Pythonオブジェクトの呼び出し中に最大再帰深度を超えました。