力扣题/回溯/N 皇后-解题思路

时间:2024-10-12 17:05:13
  1. 使用深度遍历dfs
  2. 向左斜线 => 行下标与列下标差值相同向右斜线 => 行下标与列下标之和相同
  3. n行n列的网格,斜行有n*2-1条。
  4. 一列只能放一个Q,一行只能放一个Q
  5. colslash_leftslash_right三个集合,分别记录左斜线上右斜线上是否有Q。
  6. 综上,只需要遍历每一列,每次放Q时,对于每个位置判断其是否在三个集合中,如果三个集合都不包含当前位置,则当前位置是可以放Q
  7. 如果可以放Q,则记录左斜线上右斜线上相应下标为 true的有Q状态,继续遍历下一行,如果可以遍历完所有行则获得一种解法。