首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将数字分解为彼此最接近的求和

将数字分解为彼此最接近的求和
EN

Stack Overflow用户
提问于 2014-06-05 22:51:09
回答 2查看 105关注 0票数 1

我希望相亲们能尽可能接近对方。

X和y -> "y相距最近的求和“

15和2 -> 7+8

15和3 -> 5+5+5

15和4 -> 4+4+4+3

15和5 -> 3+3+3+3+3

15和6 -> 2+2+2+3+3+3

..。

如果我除以x/y,得到一个整数,解就是y乘以那个整数。但是,如果我得到一个小数,它会变得更复杂,如上面的例子所示。

我如何使用任何x和y(最好使用javascript代码)来计算那些“最接近彼此的求和”?

EN

回答 2

Stack Overflow用户

发布于 2014-06-05 23:02:16

代码语言:javascript
复制
function closest_summands(x, y) {
    var result = [],
        n = Math.floor(x / y),
        i, j;
    for (i = 0, j = x % y; i < y; i++, j--) {
        result.push(n + (j > 0 ? 1 : 0));
    }
    return result;
}
票数 1
EN

Stack Overflow用户

发布于 2014-06-05 22:59:03

如果您从Math.floor(x/y)*y中减去x,您可以使用Bresenham线算法以最小的利差将其余部分分散到条款上。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24071481

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档