doudiao2335 2017-08-02 07:15
浏览 26
已采纳

另一个FizzBu​​zz解决方案[关闭]

I was in a job interview and was asked to solve FizzBuzz with PHP.

Write a program that prints the numbers from 1 to 100. But for multiples of three print “Fizz” instead of the number and for the multiples of five print “Buzz”. For numbers which are multiples of both three and five print “FizzBuzz”.

I never heard of FizzBuzz before but here is how I solved it:

for ($i = 1; $i <= 100; $i++){
   if($i / 3 == round($i / 3) && $i / 5 == round($i / 5)){
      echo $i . " is FizzBuzz<br />";
   }
   else if($i / 3 == round($i / 3)){
      echo $i . " is Fizz<br />";
   }
   else if($i / 5 == round($i / 5)){
      echo $i . " is Buzz<br />";
   }
   else {
      echo $i."<br />";
   }
}

I googled and didn't find any solution with round and that got me thinking that maybe there is something wrong with it, this is one of the solutions I found that is close to mine:

for ($i = 1; $i <= 100; $i++){
   if($i % 3 == 0 && $i % 5 ==0){
      echo "FizzBuzz<br />";
   }
   else if($i % 3 == 0){
      echo "Fizz<br />";
   }
   else if($i % 5 == 0){
      echo "Buzz<br />";
   }
   else {
      echo $i."<br />";
   }
}

My code is working fine but is there anything wrong with it that I don't see?

  • 写回答

3条回答 默认 最新

  • douhushen3241 2017-08-02 07:20
    关注

    Actually they are testing how you will solve such simple task. It should be increadibly optimized, the code shouldbe clean and easy readable.

    Your version of code is not good. The version you've found in the internet is better, but it's not ideal from the point of the optimization.

    Try to think how to get the goal with less actions.

    Some tips:

    • do not use functions (such as range) for this task - it will only slow down the script execution time
    • use operator "for" for this task, do not use any other (while, do-while, foreach), because operator "for" the best fits in this case (you know how many iterations you need).
    • do not use round function, use modulus operator "%", because any function works slower than any operator
    • in the result you need to get code, in which the number of operations will be the least as possible (the number of "if" statements, the number of operators like "==" or "%"

      • Use 15 instead of % 3 && % 5 - less calculations - faster execution time.

    My example of code:

    for ($i = 1; $i <= 100; $i++) {
        if ($i % 15 == 0) {
            echo 'FizzBuzz<br>';
        } elseif ($i % 3 == 0) {
            echo 'Fizz<br>';
        } elseif ($i % 5 == 0) {
            echo 'Buzz<br>';
        } else {
            echo $i . '<br>';
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。