永发信息网

c++编程解决趣味问题

答案:1  悬赏:30  手机版
解决时间 2021-11-30 01:10
c++编程解决趣味问题
最佳答案
C++经典实用趣味编程百例精解(98)-八皇后问题 在一个8×8国际象棋盘上,有8个皇后,每个皇后占一格; 要求皇后间不会出现相互“攻击”的现象, 即不能有两个皇后处在同一行、同一列或同一对角线上。 问共有多少种不同的方法。 *问题分析与算法设计 这是一个古老的具有代表性的问题,用计算机求解时的算法也很多, 这里仅介绍一种。 采用一维数组来进行处理。数组的下标i表示棋盘上的第i列,a[ i]的值表示皇后在第i列所放的位置。如:a[1]=5, 表示在棋盘的第一例的第五行放一个皇后。 程序中首先假定a[1]=1, 表示第一个皇后放在棋盘的第一列的第一行的位置上, 然后试探第二列中皇后可能的位置,找到合适的位置后, 再处理后续的各列,这样通过各列的反复试探, 可以最终找出皇后的全部摆放方法。 程序采用回溯法,算法的细节参看程序。 *程序说明与注释 #include #define NUM 8 int a[NUM+1]; int main() { int i,k,flag,not_finish=1,count=0; i=1; a[1]=1; printf("The possible configuration of 8 queens are:\n"); while(not_finish) { while(not_finish&&i<=NUM) { for(flag=1,k=1;flag&&k1&&a[i]==NUM) a[i]=1; else if(i==1&&a[i]==NUM) not_finish=0; else a[i]++; } else if(a[i]==NUM) a[i]=1; else a[i]++; } else if(++i<=NUM) if(a[i-1]==NUM) a[i]=1; else a[i]=a[i-1]+1; } if(not_finish) { ++count; printf((count-1)%3?" [%2d]: ":" \n[%2d]: ",count); for(k=1;k<=NUM;k++) printf(" %d",a[k]); if(a[NUM-1]
麻烦采纳,谢谢!
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
峰峰三号是怎么火的?
如何面对亲人的背叛
因为家暴离婚 孩子该归谁
如图,在△ABC中,边AC的垂直平分线分别交BC
成都高新区天府二街138号蜀都中心二期1栋3单
沃得拖拉机售后三包是不是到全国人何地区都一
求FL studio 的各种伴奏,钢琴逼真效果比较好
叶子上有7个鱼刺打一成语疯狂
以帆船为主题的歌曲
为什么大家都说宜瓷龙陶瓷涂料比较好,我看不
如图,AB∥CD,∠CDE=50°,∠A=30°,则∠E=
香港湾仔骆克道利临大厦1303室是香港龙宝实业
瑞安办护照在哪里
右大跨疼里很里,严重吗
车之盾汽车防盗器怎么学习遥控器
推荐资讯
有能给我看的女生吗
本年利润如何冲减以前年度损益调整
这个是什么软件p的ins框
写雷的四字词语
日本漫画的人物眼睛的高光区和亮光区怎么画
怎么加入麦田计划
巨骨蛇鱼的鱼苗哪有
江湖传奇地址在什么地方,想过去办事,
要在excel中查找某一列里1.1的个数
苹果七有点卡,才用了一年不到,怎么办
我只想知道蓝色眼白能不能戴隐形眼镜
如何维修打印机,打印机部分文字打印不出来。
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?