2 回答
TA贡献1744条经验 获得超4个赞
不确定是否足够优雅。我不会为此使用函数式编程,简单的循环就足够了。由于边界条件(当条件触发时,它应应用于下一个值),此分配非常棘手。这意味着要么有一些 if 子句,要么只是反向迭代。
简单的java代码:
double[] values = {0.35, 0.12,0.05,0.25,0.23 };
double cumulative = 0;
for(int i = values.length-1; i >= 0 ; i--) {
cumulative += values[i];
double c = cumulative < 0.5 ? cumulative :1 - cumulative + values[i];
System.out.println("c[" + i + "]=" + c );
}
生产:
c[4]=0.23
c[3]=0.48
c[2]=0.52
c[1]=0.47
c[0]=0.35
JavaScript 版本是:
const data = [
{ value: 0.35, name: 'a' },
{ value: 0.12, name: 'b' },
{ value: 0.05, name: 'c' },
{ value: 0.25, name: 'd' },
{ value: 0.23, name: 'e' },
];
for(let i = data.length - 1, cumulated = 0; i >= 0; i--) {
cumulated += data[i].value;
data[i].cumulated = cumulated < 0.5 ? cumulated : 1 - cumulated + data[i].value;
}
console.log(data);
TA贡献1779条经验 获得超6个赞
您可以对总和进行闭包,并在加/减值的前半部分或后半部分设置一个标志。
对于最后一个对象,采用原始值以省略浮点运算错误。
const
data = [{ value: 0.35, name: 'a' }, { value: 0.12, name: 'b' }, { value: 0.05, name: 'c' }, { value: 0.25, name: 'd' }, { value: 0.23, name: 'e' }],
result = data.map(((cumulativeValue, first) => (o, i, { length }) => {
if (first) cumulativeValue += o.value;
const temp = { ...o, cumulativeValue };
if (!first) cumulativeValue -= o.value;
if (cumulativeValue > 0.5) {
first = false;
cumulativeValue = 1 - cumulativeValue;
}
return i + 1 === length
? { ...o, cumulativeValue: o.value }
: temp;
})(0, true))
console.log(result)
.as-console-wrapper { max-height: 100% !important; top: 0; }
添加回答
举报