日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode51 --- solveNQueens

發(fā)布時間:2024/7/23 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode51 --- solveNQueens 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1 題目

n?皇后問題 研究的是如何將 n?個皇后放置在 n×n 的棋盤上,并且使皇后彼此之間不能相互攻擊。

給你一個整數(shù) n ,返回所有不同的?n?皇后問題 的解決方案。

每一種解法包含一個不同的?n 皇后問題 的棋子放置方案,該方案中 'Q' 和 '.' 分別代表了皇后和空位。

2 解法

以行 為遍歷單位, 依次確定每行的Q的列數(shù), 并用位運算的方式記錄每個列, 兩條斜線是否已經(jīng)被占用, 并用遞歸(感覺不用遞歸也可以, 畢竟是二維的)的方式調(diào)用下一行, 至于回溯的方式就是, 當行的每一個列完成后要把其位置退出來:

class Solution { public:int Q_num;int col;int row_plus_col;int row_col_plus_n_1;void do_flip(int r_idx, int c_idx){col ^= (1 << c_idx);row_plus_col ^= (1 << (r_idx + c_idx));row_col_plus_n_1 ^= (1 << (r_idx - c_idx + Q_num - 1));}void dfs(vector<pair<int, int>> &tmp_Q_pos, vector<vector<pair<int, int>>> &all_Q_pos, int cur_r_idx) {if (cur_r_idx == Q_num) {all_Q_pos.push_back(tmp_Q_pos);return;}int c_idx = 0;while (c_idx < Q_num) {if ((col & (1 << c_idx)) == 0 &&(row_plus_col & (1 << (cur_r_idx + c_idx))) == 0 &&(row_col_plus_n_1 & (1 << (cur_r_idx - c_idx + Q_num - 1))) == 0) {do_flip(cur_r_idx, c_idx);tmp_Q_pos.push_back(make_pair(cur_r_idx, c_idx));dfs(tmp_Q_pos, all_Q_pos, cur_r_idx + 1);tmp_Q_pos.pop_back();do_flip(cur_r_idx, c_idx);}c_idx ++;}}vector<vector<string>> solveNQueens(int n) {Q_num = n;col = 0;row_plus_col = 0;row_col_plus_n_1 = 0;vector<vector<pair<int, int>>> all_Q_pos;vector<pair<int, int>> tmp_Q_pos;dfs(tmp_Q_pos, all_Q_pos, 0);vector<vector<string>> all_res(all_Q_pos.size(), vector<string>(n, string(n, '.')));for (int res_index = 0; res_index < all_Q_pos.size(); res_index ++) {for_each(all_Q_pos[res_index].begin(), all_Q_pos[res_index].end(), [&](auto pair){all_res[res_index][pair.first][pair.second] = 'Q';});}return all_res;} };

?

總結(jié)

以上是生活随笔為你收集整理的leetcode51 --- solveNQueens的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。