聚合中的迭代器(linq)

本文关键字:linq 迭代器 | 更新日期: 2023-09-27 18:28:50

假设我有一个像这样的小整数数组:

{10,20,30}

现在,对于该数组中的项目,我想应用以下公式:

10^(arrayLenght-1) + 20^{arrayLenght-2) + 30^{arrayLenght-3}

有没有一种方法可以通过使用linq-aggregate方法来实现这一点,尽管你需要某种迭代器,但当我看到这一点时,aggregate并没有实现?

聚合中的迭代器(linq)

以下是我的操作方法:

array.Select((num, index) => Math.Pow(num, items.Length - index - 1)).Sum();

试试这个:

var a = new int[]{10, 20, 30};
int i = 0;
a.Sum(x => Math.Pow(x, a.Length - ++i));

它使用Sum方法,因为它在这里更准确。

你也可以使用:

var a = new int[]{10, 20, 30};
a.Select((x,i)=> Math.Pow(x,a.Length-(i+1)));

您可以尝试对选择的结果求和,而不是使用聚合

result = values.Select((t, index) => Math.Pow(t, (values.Length - (index + 1)))).Sum();