方程式で使用される配列内の数値を徹底的に検索するように設定されたノートブックがあります。方程式が定義された変数と等しい場合、方程式内の変数の値を返します。唯一の問題は、最後の For ループの If ステートメントが true/false/どちらの関数も実行しないことです。私がそれを何かにできるようにする唯一の方法は、汎用の Print[blah] を使用することです。これにより、すべての For ループを介してすべての反復を完全に印刷することができます。これが私がこれまでに持っているものです-
AvTarget := -95
arr := {1, 1.1, 1.2, 1.3, 1.5, 1.6, 1.8, 2, 2.2, 2.4, 2.7, 3, 3.3,
3.6, 3.9, 4.3, 4.7, 5.1, 5.6, 6.2, 6.8, 7.5, 8.2, 9.1, 10}
trueArr := {}
falseArr := {}
For[i = 1, i <= Length[arr], i = i + 1,
For[j = 1, j <= Length[arr], j = j + 1,
For[k = 1, k <= Length[arr], k = k + 1,
If[Abs[
AvTarget - (arr[[i]] + arr[[k]] + (arr[[i]] + arr[[k]])/
arr[[j]])] < 1000, Append[trueArr, {i, j, k}],
Append[falseArr, 1], Append[falseArr, 0]]
]
]
]
Length[trueArr]
Length[falseArr]
Mathematica でループを扱ったことがないので、何が問題なのかわかりません。
編集-わかり ましたので、このコードは必要な方法で機能するようになりました-
AvTarget = -95;
tol = 0.1;
arr := {1, 1.1, 1.2, 1.3, 1.5, 1.6, 1.8, 2, 2.2, 2.4, 2.7, 3, 3.3,
3.6, 3.9, 4.3, 4.7, 5.1, 5.6, 6.2, 6.8, 7.5, 8.2, 9.1, 10}
trueArr = {};
falseArr = {};
For[i = 1, i <= Length[arr], i++,
For[j = 1, j <= Length[arr], j++,
For[k = 1, k <= Length[arr], k++,
If[Abs[
AvTarget - (-(arr[[i]] + arr[[k]] + (arr[[i]]*arr[[k]])/
arr[[j]]))] <= tol,
trueArr = Append[trueArr, {arr[[i]], arr[[j]], arr[[k]]}],
Append[falseArr, 1], Append[falseArr, 0]]
]
]
]
Length[trueArr]
そこから、長さ > 0 の場合、If を追加して結果を表示するだけです。公差内のすべての結果を AvTarget に近い順に印刷するにはどうすればよいでしょうか?