我正在寻找可以给我写一个脚本来输出以下模式的人:
http://img84.imageshack.us/img84/3038/82351644.png
从中间的0开始,然后是1,左边是2,下边3,右边......你明白了。 - 它总是0到9并重新开始...
我发现了这个topic,但它明显不同于我的要求。 因为我对php没有很好的理解而且“专业人士”在这里, 我很好地问,有人会花一些时间为我做这件事。 那太好了!此外,如果我可以在变量中设置脚本执行了多少“轮次”,那将是非常棒的! - 非常感谢
答案 0 :(得分:8)
仅仅因为我没有更好的事情要做,我总是喜欢挑战:
<?php
// A few constants.
define('DOWN', 0);
define('LEFT', 3);
define('RIGHT', 1);
define('UP', 2);
// Dictates the size of the spiral.
$size = 11;
// The initial number.
$number = 0;
// The initial direction.
$direction = RIGHT;
// The distance and number of points remaining before switching direction.
$remain = $distance = 1;
// The initial "x" and "y" point.
$y = $x = round($size / 2);
// The dimension of the spiral.
$dimension = $size * $size;
// Loop
for ( $count = 0; $count < $dimension; $count++ )
{
// Add the current number to the "x" and "y" coordinates.
$spiral[$x][$y] = $number;
// Depending on the direction, set the "x" or "y" value.
switch ( $direction )
{
case LEFT: $y--; break;
case UP: $x--; break;
case DOWN: $x++; break;
case RIGHT: $y++; break;
}
// If the distance remaining is "0", switch direction.
if ( --$remain == 0 )
{
switch ( $direction )
{
case DOWN:
$direction = LEFT;
$distance++;
break;
case UP:
$distance++;
default:
$direction--;
break;
}
// Reset the distance remaining.
$remain = $distance;
}
// Increment the number or reset it to 0 if the number is 9.
if ( $number < 9 )
$number++;
else
$number = 0;
}
// Sort by "x" numerically.
ksort($spiral, SORT_NUMERIC);
foreach ( $spiral as &$x )
{
// Sort by "y" numerically.
ksort($x, SORT_NUMERIC);
foreach ( $x as $ykey => $y )
// Output the number.
echo $y . ' ';
// Skip a line.
echo PHP_EOL;
}
<强>输出:强>
0 1 2 3 4 5 6 7 8 9 0
9 2 3 4 5 6 7 8 9 0 1
8 1 2 3 4 5 6 7 8 9 2
7 0 1 0 1 2 3 4 5 0 3
6 9 0 9 6 7 8 9 6 1 4
5 8 9 8 5 0 1 0 7 2 5
4 7 8 7 4 3 2 1 8 3 6
3 6 7 6 5 4 3 2 9 4 7
2 5 6 5 4 3 2 1 0 5 8
1 4 3 2 1 0 9 8 7 6 9
0 9 8 7 6 5 4 3 2 1 0