首页 > 其他 > 详细

n皇后问题——关于斜线的编号

时间:2017-12-03 16:04:50      阅读:368      评论:0      收藏:0      [点我收藏+]

题目大意:在n*n的棋盘中,放置n个皇后(同一行、同一列、同一斜线,只有一个皇后)

这道题是一道非常经典的dfs模板题,同一行、同一列的判断不是很难,但同一斜线有一定的难度,下面给出关于斜线编号的解决方法

我们就先以4*4的棋盘为例

技术分享图片

我们把被标红的这一条暂且称之为主对角线

技术分享图片

观察一下主对角线上的点坐标规律

技术分享图片

我们发现主对角线上的点的坐标(x,y)满足x==y

下面看看其他的斜线有怎样的性质

技术分享图片

在蓝色这条斜线上的坐标(x,y)满足x-y==1

在粉色这条斜线上的坐标(x,y)满足x-y==-1

同样的,我们也可以吧主对角线的坐标(x,y)表示为x-y==0

所以可以用x-y来计算斜线的编号

x-y的值是从(-4+1)~(4-1)

但是数组下标(在c++)没有负数,所以我们把x-y+n当做数组下标,编号从1~(2*4-1)

技术分享图片

同样的,对于n*n的棋盘,共有2n+1条左斜线,我们可以把向左倾斜的斜线编号为(x-y+n)

下面来解决一下向右倾斜的斜线编号(还是以4*4的棋盘为例)

不难看出,在标红的这条向右倾斜的主对角线上点的坐标满足x+y==5

技术分享图片

在粉色的这条斜线上x+y==4

在蓝色的这条斜线上x+y==6

技术分享图片

同样的,向右倾斜的斜线共有(2*4-1)条,按照x+y来编号,编号为2~8,因为我们普遍采用从1开始的数组下标

所以我们用(x+y-1)当做数组下标,范围是1~7

同样的,对于n*n的棋盘,共有2n+1条右斜线,我们可以把向右倾斜的斜线标号为(x+y-1)

 

n皇后问题——关于斜线的编号

原文:http://www.cnblogs.com/Peper/p/7966253.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!