doubleのArrayListがあり、すべての数値の平均を見つける必要があります。配列リスト内のDoubleインスタンスの数は一定ではなく、2である可能性があり、90である可能性があります。アルゴリズムを自分で取得するために何時間も試していましたが、とにかく動作させることができませんでした。
何かアドバイスはありますか?または、この平均を取得するために、既存のライブラリにリンクすることができますか?
ありがとうございました
sum
変数を作成します。
double sum = 0;
for ループを使用してリスト内の要素を調べます。
for (double d : yourList)
sum
各反復で、現在の値に追加します。
sum += d;
ループの後、平均を見つけるためsum
に、リスト内の要素の数で割ります。
double avg = sum / yourList.size();
これは簡単すぎると思うすべての人のために...
上記の解決策は実際には完全ではありません。リストの最初の 2 つの要素が非常に大きく、最後の要素が小さい場合、sum += d
double の精度が原因で、最後に向かって違いが生じない場合があります。
解決策は、平均計算を行う前にリストをソートすることです。
Collections.sort(doublesList);
小さな要素が最初に追加されるようになりました。これにより、それらがすべて可能な限り正確にカウントされ、最終的な合計に貢献することが保証されます:-)
ストリームが好きなら:
List<Number> list = Arrays.asList(number1, number2, number3, number4);
// calculate the average
double average = list.stream()
.mapToDouble(Number::doubleValue)
.average()
.getAsDouble();
平均の定義は、すべての値の合計を値の数で割ったものです。値をループして追加し、合計をリストのサイズで割ります。
質問になってないかもしれませんが・・・こんな感じではないですか?
double sum = 0.0;
for (double element : list) {
sum += element;
}
double average = sum / list.size();
「すべての数値の平均」とは、リスト内のすべての double の平均を意味する場合、リスト内のすべての double を (ループで) 追加し、その合計をリスト内の double の数で割るだけです。
やってみました:
List<Double> list = new ArrayList<Double>();
...
double countTotal = 0;
for (Double number : list)
{
countTotal += number;
}
double average = countTotal / list.size();
リスト全体を合計するときにオーバーフローが心配な場合は、移動平均を使用できます。より多くの操作があるため、すべてを足し合わせて一度分割するよりも遅くなります。
for (int x = 0; x < list.size(); x++)
average = (average / (x+1)) * (x) + list.get(x) / (x+1);