DownValuesに保存されているReturn []
Aug 26 2020
例:
f[x_] := f[x] = (If[x < 0, Return[x]]; x)
f[1];
f[-5];
DownValues[f][[1 ;; 2]]
(* {HoldPattern[f[-5]] :> Return[-5], HoldPattern[f[1]] :> 1} *)
返された値をReturn[]。なしで保存したい。重要な場合、実際の関数は次のようになります。
f[list_,n_] := f[list,n] = Block[{li = list, moreVars},
Which[
n == 0, Return@li,
li[[i1]] > 0, li[[i1]]--,
li[[i2]] > 0, li[[i2]]--,
True, Return@li
];
f[li, n - If[bla, 2, 1]]
]
回答
1 Hausdorff Aug 26 2020 at 19:21
それほど派手ではありませんが、代わりに使用することができます。
f[x_] := f[x] = (If[x < 0, Return[x]]; x) /. Return[z_] :> z
f[1]; f[-5];
DownValues[f][[1 ;; 2]]
{HoldPattern[f[-5]] :> -5, HoldPattern[f[1]] :> 1}
あるいは、おそらくReturn完全に取り除くことができます。例えば、
f[list_, n_] := f[list, n] =
Block[{li = list, moreVars},
Which[
n == 0,
li,
li[[i1]] > 0,
li[[i1]]--;
f[li, n - If[bla, 2, 1]],
li[[i2]] > 0,
li[[i2]]--;
f[li, n - If[bla, 2, 1]],
True,
li]
]
またはより機能的なアプローチで
f[list_, n_] /; n == 0 := f[list, n] = list;
f[list_, n_] /; list[[i1]] > 0 := f[list, n] =
Block[{li = list, moreVars},
li[[i1]]--;
f[li, n - If[bla, 2, 1]]
];
f[list_, n_] /; list[[i2]] > 0 := f[list, n] =
Block[{li = list, moreVars},
li[[i2]]--;
f[li, n - If[bla, 2, 1]]
];
f[list_, n_] := f[list, n] = list;
2 CarlWoll Aug 26 2020 at 22:14
の2引数バージョンを使用できますReturn:
Clear[f]
f[x_] := f[x] = (If[x<0, Return[x, CompoundExpression]];x)
f[1];
f[-5];
DownValues[f][[1;;2]]
{HoldPattern [f [-5]]:> -5、HoldPattern [f [1]]:> 1}
single-argの問題Returnは、どの構造が返されるかを決定するためにヒューリスティックを使用する必要があることです。
1 SjoerdSmit Aug 26 2020 at 19:43
この場合、私が考えるThrowとCatch、おそらくあなたが何をしたいのためのより良い構築物で:
f[list_,n_] := f[list,n] = Catch @ Block[{li = list, moreVars},
Which[
n == 0, Throw[li],
li[[i1]] > 0, li[[i1]]--,
li[[i2]] > 0, li[[i2]]--,
True, Throw[li]
];
f[li, n - If[bla, 2, 1]]
]
これにより、よりもプログラムフローをより適切に制御できますReturn。