commit
c09c5b1940
74
php/39_backtracking/queens.php
Normal file
74
php/39_backtracking/queens.php
Normal file
@ -0,0 +1,74 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* 8皇后解法,共92种解法 回溯思想
|
||||
* Class Queen
|
||||
*/
|
||||
class Queen
|
||||
{
|
||||
public $result = [];
|
||||
|
||||
function cal8queens($row)
|
||||
{
|
||||
if ($row == 8) {
|
||||
$this->printQueens();
|
||||
return;
|
||||
}
|
||||
|
||||
//每一行有8中放法
|
||||
for($column = 0; $column < 8; $column++) {
|
||||
if ($this->isOk($row, $column)) {
|
||||
$this->result[$row] = $column;
|
||||
$this->cal8queens($row + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
//row行的column列是否合适
|
||||
function isOk($row, $column)
|
||||
{
|
||||
$leftup = $column - 1;
|
||||
$rightdown = $column + 1;
|
||||
|
||||
for ($i = $row - 1; $i >= 0; $i--) {
|
||||
//判断上一行的 column 列是否有值
|
||||
if ($this->result[$i] == $column) {
|
||||
return false;
|
||||
}
|
||||
|
||||
//左上角是否有值
|
||||
if ($leftup >= 0 && $this->result[$i] == $leftup) {
|
||||
return false;
|
||||
}
|
||||
|
||||
//右下角是否有值
|
||||
if ($rightdown < 8 && $this->result[$i] == $rightdown) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$leftup--;
|
||||
$rightdown++;
|
||||
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
//打印
|
||||
function printQueens()
|
||||
{
|
||||
for ($row = 0; $row < 8; $row++) {
|
||||
for ($column = 0; $column < 8; $column++) {
|
||||
if ($this->result[$row] == $column) {
|
||||
echo 'Q';
|
||||
} else {
|
||||
echo '*';
|
||||
}
|
||||
}
|
||||
echo '<br>';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$queen = new Queen();
|
||||
$queen->cal8queens(0);
|
Loading…
Reference in New Issue
Block a user