java 如何把一堆数平均分成N份
ringa_lee
ringa_lee 2017-04-18 09:48:09
[Java讨论组]

把一堆数平均分成N份,保证每一份的和接近于所有数之和除以N,不要求平分以后的每份数据个数相等。

ringa_lee
ringa_lee

ringa_lee

全部回复(3)
PHP中文网

一堆数?数在堆里?
所有数之和?数量和还是数值和?

将数进行数据结构调整 然后对该数据结构进行分割
或者循环写入n个arr中

黄舟

典型贪婪算法

PHP中文网

均分和尾差:

<?php
header('Content-Type: text/plain; charset=utf-8');
function tail($num, $fen) {
    $avg  = bcp($num, $fen, 2);
    $tail = bcsub($num, $avg*($fen-1), 2);
    echo $num.'='.str_repeat($avg.'+', $fen-1).$tail."\n";
    return array($avg, $tail);
}
var_export(tail(100, 3)); //这堆数的和为100,有3个数
var_export(tail(100, 6)); //这堆数的和为100,有6个数
//输出:
100=33.33+33.33+33.34
array (
  0 => '33.33',
  1 => '33.34',
)
100=16.66+16.66+16.66+16.66+16.66+16.70
array (
  0 => '16.66',
  1 => '16.70',
)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号