云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > 2009-2010学年第二学期《计算机算法设计与分析》试卷A--参考答案(软07级)

2009-2010学年第二学期《计算机算法设计与分析》试卷A--参考答案(软07级)

  • 62 次阅读
  • 3 次下载
  • 2026/4/23 19:32:17

2.(15分)设n后问题的显约束条件是两个皇后不能在同一行及同一列,求解n后问题的递归的回溯算法如下。它计算可行解的个数,并将所有可行解输出。请给算法填空(包括部分循环语句和条件判断语句后面的注释)。

设x[i]的初值为i(1≤i≤n),sum的初值为0。

bool Queen :: Place(int k) {for (int j=1; j

if( abs(k-j)==abs(x[j]-x[k]) ) // 判断两个皇后是否在同一斜线 return false; return true ; }

void Queen::Backtrack(int t) {if (t>n) // 得到一个可行解 {sum++; // 可行解个数加1 for( int i=1; i<=n; i++ ) //输出可行解 count<

else for ((int j= t ; j<=n ; j++ ) {Swap( x[t] , x[j] );

if (Place(t)) // 检查第t个皇后与前t-1个皇后是否在同一斜线 Backtrack( t+1 ); Swap( x[t] , x[j] ) ; } }

5

  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

2.(15分)设n后问题的显约束条件是两个皇后不能在同一行及同一列,求解n后问题的递归的回溯算法如下。它计算可行解的个数,并将所有可行解输出。请给算法填空(包括部分循环语句和条件判断语句后面的注释)。 设x[i]的初值为i(1≤i≤n),sum的初值为0。 bool Queen :: Place(int k) {for (int j=1; jn) // 得到一个可行解 {sum++; // 可行解个数加1 for( int

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com