1. 程式人生 > >php 算法之------------怎樣打印出下圖

php 算法之------------怎樣打印出下圖

div oot sni 一行 ng- int keys 維數 fill

自己偶爾看到了下圖。於是用php打印出下圖。

技術分享

兩種方法解決此問題:

方法一:依據圖分析該圖是一個二維數組,可用二維數組解決此類問題,6行就是6個數組,每一行就代表數組有多少個元素。知道每一個數組元素的個數。不就能夠知道數組中有哪幾個元素嗎?

function array_chunk_vertical($arr, $colun)
{
    $arr_length = count($arr);
    $parem = floor($arr_length / $colun);
    $pare = $arr_length % $colun;
    $ar = array();
    for ($i = 0; $i < $colun; $i ++) {
        $par = $i == $colun - 1 ? 1 : 5;
        $ar[] = $par;
    }
    $newarray = array();
    foreach ($ar as $value) {
        for ($i = 0; $i < $value; $i ++) {
            $newarray[$i][] = array_shift($arr);
        }
    }
    return $newarray;
}

$arr = range(1, 31);
$data = array_chunk_vertical($arr, 7);
foreach ($data as $value) {
    foreach ($value as $va) {
        printf('[%2s]', $va);
    }
    echo "<br/>";
}

方法二:如代碼。先給出size個空數組。在空數組中填充元素。

詳細方法例如以下:

<?

php function array_chunk_vertical($input, $size, $preserve_keys = FALSE, $size_is_horizontal = false) { $chunks = array(); if ($size_is_horizontal) { $chunk_count = ceil(count($input) / $size); } else { $chunk_count = $size; } for ($chunk_index = 0; $chunk_index < $chunk_count; $chunk_index++) { $chunks[] = array(); } $chunk_index = 0; foreach ($input as $key => $value) { if ($preserve_keys) { $chunks[$chunk_index][$key] = $value; } else { $chunks[$chunk_index][] = $value; } if (++$chunk_index == $chunk_count) { $chunk_index = 0; } } return $chunks; } $data=range(1,31); $newdata=array_chunk_vertical($data,6); foreach ($newdata as $root){ foreach ($root as $val){ printf('[%2s]',$val); } echo "<br/>"; }


php 算法之------------怎樣打印出下圖