编程题分享:有⼀堆糖果,其数量为n,现将糖果分成不同数量的堆数

3 篇文章 0 订阅
  • 背景
    近期面试遇到一家公司的编程题,觉得挺有参考价值
    此处使用 PHP语言,进行编码测试,
    编码之前要进行思路分析,避免无头苍蝇,走一步看一步
    最后,希望后期面试顺利!欢迎指摘 .

  • 题目:

	编程题:
	有⼀堆糖果,其数量为n,
	现将糖果分成不同数量的堆数(每堆数量均为整数,最少为1),
	请算出糖果堆对应数量的最⼤乘积是多少,并给出对应的分配⽅案;
	举例:糖果数量为8,可以得到的乘积最⼤为18,对应的分配⽅案为【2,3,3】;
  • 思路分析:

初始测试数据比较小,可以在草稿纸上穷举分配方案,寻找规律,发现:

  1. 当数量小于5时,最大的乘积就是本身,无需分配
  2. 其次注意到分配后的数目如果是1则毫无意义,
  3. 同时穷举发现,越靠近数字3,乘积越大,得到的分配方案最符合要求
  4. 所以算法重点处理数量大于5的情况
    首先获取除3的整数部分 $count, 和取模数字 $mod
    根据变量 $count ,判断乘积,for 循环处理,并得到每个分配数字
    分析 $mod 变量的影响,使得分配数尽可能靠近数字 3
    最后,简单测试数量 n,验证分配方案是否符合实际要求 .
  • 编码如下:
**
 * 有⼀堆糖果,其数量为n,现将糖果分成不同数量的堆数
 * @param int $z_number 糖果数量
 * @return string 检测结果
 */
public function zingFunc($z_number = 0){
    //检验数据规范性
    $res_msg = '分配数字为:'.$z_number;
    //最大乘积
    $max_result = 1;
    //方案分配
    $option_msg = '';
    if (is_int($z_number)&& $z_number > 0){
        if ($z_number < 5){
            $max_result = $z_number;
            $option_msg = $z_number;
        }else{
            //整数大于5,详细分析
            //取商的整数
            $count = intval($z_number/3);
            //除3取模
            $mod = $z_number%3;
            $arr_option = [];

            if ($mod == 0){
                //此时正好是统一分配
                for ($i=0;$i<$count;$i++){
                    $max_result*=3;
                    $arr_option[] = 3;
                }
            }elseif ($mod == 1){
                //对其中的一个分配数加1
                for ($i=0;$i<$count-1;$i++){
                    $max_result*=3;
                    $arr_option[] = 3;
                }
                $max_result *=4;
                $arr_option[] = 4;
            }else{
                //余数为2的时候,可以对前面取两堆,分别加1
                for ($i=0;$i<$count-2;$i++){
                    $max_result*=3;
                    $arr_option[] = 3;
                }
                $max_result *=4;
                $max_result *=4;
                $arr_option[] = 4;
                $arr_option[] = 4;
            }
            $option_msg = implode(',',$arr_option);
        }
        $res_msg .= ',最大乘积为:'.$max_result.',方案分配为:【'.$option_msg.'】';
    }else{
        $res_msg .= ',数据输入不是正整数';
    }
    //echo('<br>'.$res_msg);
    return $res_msg;
}
  • 测试截图:
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值