算法

有100盏灯和100个开关,刚开始的时候灯全是灭的,someone第一轮按下所有开关(开的按一下变灭,灭的按一下变开),第二轮隔一个按一下(偶数个按),第三轮隔2个(3的倍数个按),求第100轮之后有多少盏灯是亮的。

<?php
//解法1
//遍历解法
$array=array_fill(1,100,1);
for($i=2;$i<=100;$i++)
{
    for($j=1;$j<=100;$j++)
    {
        if($j%$i==0)
        {
            $array[$j]=1-$array[$j];
        }
        
    }
}

var_dump(array_shift(array_count_values($array)));

//解法2
//算法解法
$max_sqrt=intval(sqrt(100));
for($i=1;$i<=$max_sqrt;$i++)
{
    echo "第".$i*$i."盏灯是亮着的<br/>";
}
echo "一共".$max_sqrt."盏灯是亮着的";

 

posted @ 2015-10-09 10:37  李照耀  阅读(228)  评论(0编辑  收藏  举报