私が作成した小さなアプリケーションを使用すると、ユーザーは2つの配列にさまざまなアイテムを追加できます。一部のロジックは、各配列の内容から数値を計算します。
配列x内のすべてのアイテムは、配列yに配置したり、元に戻したりすることができます。配列yに属するアイテムは、移動できません(配列xから移動された場合を除く)。
ユーザーは、単純なjavascript uiを使用して、これらのアイテムを2つのリストで移動できます。物事を簡単にするために、私はもともと素朴なスクリプトを作成しました。
- アイテムをaからyに移動しました。
- この「可能性」を使用していくつかのロジックを実行しました
- 結果が以前よりも小さかった場合は、xをyのままにします。
- そうでない場合、xはxに残ります。
- xの次の項目に移動して、繰り返します。
私はこれが効果がないことを知っていました。私は読み回して、可能性または「順列」を覚えるためにビット単位の数学を使用してこれを行うように言われましたが、この段階でこの特定の問題を回避するのに苦労しています。
誰かが説明できれば(擬似コードは問題ありません)、次のことを達成するための最良の方法は何でしょうか。私は非常に感謝しています。
配列x=[100,200,300,400,500]配列y=[50,150,350,900]
これらの2つの配列を使用して、xの値ごとに、その値と他のすべての値のすべての組み合わせをxから配列yにプッシュします。それぞれについて、いくつかのロジックを実行します(つまり、テスト結果とこの「順列」を配列(xとyを表す2つの配列のオブジェクト)に格納します)。これは、大きな配列では非常に高価であり、多くのことを繰り返す可能性が高いと予測しています。組み合わせ。私はほとんどそこにいるように感じますが、この最後の段階で失われました。
長い説明でごめんなさい、そして事前に感謝します!