国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C++實現LeetCode(52.N皇后問題之二)

C++實現LeetCode(52.N皇后問題之二)

2021-11-29 14:52Grandyang C/C++

這篇文章主要介紹了C++實現LeetCode(52.N皇后問題之二),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下

[LeetCode] 52. N-Queens II N皇后問題之二

The n-queens puzzle is the problem of placing nqueens on an n×n chessboard such that no two queens attack each other.

C++實現LeetCode(52.N皇后問題之二)

Given an integer n, return the number of distinct solutions to the n-queens puzzle.

Example:

Input: 4
Output: 2
Explanation: There are two distinct solutions to the 4-queens puzzle as shown below.
[
[".Q..",  // Solution 1
"...Q",
"Q...",
"..Q."],

 ["..Q.",  // Solution 2
"Q...",
"...Q",
".Q.."]
]

這道題是之前那道 N-Queens 的延伸,說是延伸其實我覺得兩者順序應該顛倒一樣,上一道題比這道題還要稍稍復雜一些,兩者本質上沒有啥區別,都是要用回溯法 Backtracking 來解,如果理解了之前那道題的思路,此題只要做很小的改動即可,不再需要求出具體的皇后的擺法,只需要每次生成一種解法時,計數器加一即可,代碼如下:

解法一:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class Solution {
public:
    int totalNQueens(int n) {
        int res = 0;
        vector<int> pos(n, -1);
        helper(pos, 0, res);
        return res;
    }
    void helper(vector<int>& pos, int row, int& res) {
        int n = pos.size();
        if (row == n) ++res;
        for (int col = 0; col < n; ++col) {
            if (isValid(pos, row, col)) {
                pos[row] = col;
                helper(pos, row + 1, res);
                pos[row] = -1;
            }
        }
    }
    bool isValid(vector<int>& pos, int row, int col) {
        for (int i = 0; i < row; ++i) {
            if (col == pos[i] || abs(row - i) == abs(col - pos[i])) {
                return false;
            }
        }
        return true;
    }
};

但是其實我們并不需要知道每一行皇后的具體位置,而只需要知道會不會產生沖突即可。對于每行要新加的位置,需要看跟之前的列,對角線,及逆對角線之間是否有沖突,所以我們需要三個布爾型數組,分別來記錄之前的列 cols,對角線 diag,及逆對角線 anti_diag 上的位置,其中 cols 初始化大小為n,diag 和 anti_diag 均為 2n。列比較簡單,是哪列就直接去 cols 中查找,而對角線的話,需要處理一下,如果我們仔細觀察數組位置坐標的話,可以發現所有同一條主對角線的數,其縱坐標減去橫坐標再加n,一定是相等的。同理,同一條逆對角線上的數字,其橫縱坐標之和一定是相等的,根據這個,就可以快速判斷主逆對角線上是否有沖突。任意一個有沖突的話,直接跳過當前位置,否則對于新位置,三個數組中對應位置都賦值為 true,然后對下一行調用遞歸,遞歸返回后記得還要還原狀態,參見代碼如下:

解法二:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class Solution {
public:
    int totalNQueens(int n) {
        int res = 0;
        vector<bool> cols(n), diag(2 * n), anti_diag(2 * n);
        helper(n, 0, cols, diag, anti_diag, res);
        return res;
    }
    void helper(int n, int row, vector<bool>& cols, vector<bool>& diag, vector<bool>& anti_diag, int& res) {
        if (row == n) ++res;
        for (int col = 0; col < n; ++col) {
            int idx1 = col - row + n, idx2 = col + row;
            if (cols[col] || diag[idx1] || anti_diag[idx2]) continue;
            cols[col] = diag[idx1] = anti_diag[idx2] = true;
            helper(n, row + 1, cols, diag, anti_diag, res);
            cols[col] = diag[idx1] = anti_diag[idx2] = false;
        }
    }
};

到此這篇關于C++實現LeetCode(52.N皇后問題之二)的文章就介紹到這了,更多相關C++實現N皇后問題之二內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/grandyang/p/4380706.html

延伸 · 閱讀

精彩推薦
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 久久xx | 四虎永久在线观看 | 亚洲精品国产一区 | 搡女人真爽免费午夜网站 | 男插女青青影院 | 久久中文字幕av | 99青草 | 成人国产 | 成年人免费观看网站 | 亚洲青涩在线 | 久久亚洲国产精品 | 深夜视频在线观看 | 一区二区国产精品 | 久久a国产 | 久久精品久久久久久久久久16 | 久久成人一区二区 | 亚洲精选久久 | 国产噜噜噜噜噜久久久久久久久 | 久久国内精品 | 欧美日韩激情一区 | 欧美一区在线看 | 极品久久 | 久久久亚洲综合 | 99riav在线| 亚洲成人一级片 | 久久久精品一区 | 日本精品一区二区三区在线观看 | 欧美在线不卡 | 在线播放国产一区二区三区 | 久久久久久国产精品mv | 精品一区二区av | 国产在线视频网站 | 99免费在线播放99久久免费 | 亚洲精品区| 亚洲男人在线天堂 | 日韩不卡二区 | 天天澡天天狠天天天做 | а天堂中文最新一区二区三区 | 亚洲国产精品一区二区久久 | 一区二区免费 | 免费一级性片 |