思路是这样的,把菱形分成上下两部分,上下两部分又分成左右两部分.
上部分左边想象成一个倒直角三角形,只需要循环输出递减的空格就可以完成.
上部分右边第一行1个*,第二行3个*,依此类推,然后中间空心部分规律也是第一行0 第二行1 第三行3.那么首尾可以用if来判断
if($k==1||$k==2*$i-1),那么上半部分代码就出来了:
$n=8;
//上半部分
for($i=1;$i<=$n;$i++){
//输出空格(递减)
for($j=$n-$i;$j>=1;$j--){
echo '<span style="color:#FFF;">*</span>';
}
//输出*号,并判断首尾*号位置,其余位置输出红色*号
for($k=1;$k<=2*$i-1;$k++){
if($k==1||$k==2*$i-1){
echo '*';
}else{
echo '<span style="color:red">*</span>';
}
}
echo '<br/>';
}
下班部分同样的道理,只是需要注意层数(行数)比上半部分少一行
先输出递增的空格,然后输出递减的2*$i-1的*号,再判断首尾*号位置,其余位置输出红色*号,代码如下:
//下半部分
for($i=$n-1;$i>=1;$i--){
//输出空格(递增)
for($j=1;$j<=$n-$i;$j++){
echo '<span style="color:#FFF;">*</span>';
}
//输出*号,并判断首尾*号位置,其余位置输出红色*号
for($k=2*$i-1;$k>=1;$k--){
if($k==1||$k==2*$i-1){
echo '*';
}else{
echo '<span style="color:red">*</span>';
}
}
echo '<br/>';
}