用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - php代码库

php 解 八皇后 问题 以及 多皇后问题。

2014-12-03 作者: php源代码大全举报

[php]代码库

<? php
function f($q, $f = false) { /* $f 是标记,如果为 false 将重新初始化 */
    static $c = 0; /* 计数器, 解个数 */
    static $l = array(); /* 当前皇后存在的列, 键名记录行 */
    static $n = 0; /* 当前皇后,从0计数,表示第一个 */

    /* BUG FIX 增设初始化内容,感谢 @曹林剑 发现此BUG */
    if(!$f) {
        $c = 0;
        $l = array();
        $n = 0;
    }

    /* 尝试放入皇后 */
    for($l[$n] = 0; $l[$n] < $q; $l[$n]++) {
        /* 验证皇后是否可以放入*/
        for($i = 0; $i < $n; $i++) {
            /* 验证是否可放入,冲突直接跳出本次筛选 */
            if(($l[$i] == $l[$n] || $l[$i] - $l[$n] == $i - $n || $l[$i] - $l[$n] == $n - $i )) continue 2;
        }
        /* 验证通过,可以放置本次 */

        /* 如果没有达到最后一个 */
        if($n < ($q - 1)) {
            $n++; /* 下一个皇后 */
            f($q, true); /* 第2个参数表示不会破坏内部存放数值*/
            $n--; /* 本层还有其他位置要验证, 还原后继续验证本层 */
        }
        /* 达到最后一个, 计数器+1 */
        else {
            $c++;
        }
    }
    return $c;
}

/* f(8); 可以返回 8 皇后解个数, 要想知道所有解, 可 在  "达到最后一个,计算器+1" 部分获取解详情。 */
//该片段来自于http://yuncode.net


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...