代码随想录算法训练营第23期day29|332.重新安排行程、51. N皇后、37. 解数独

目录

一、(leetcode 332)重新安排行程

二、(leetcode 51)N皇后

三、(leetcode 37)解数独


一、(leetcode 332)重新安排行程

力扣题目链接

状态:抄代码都看不明白。

class Solution {
public:
    unordered_map> targets;
    bool backtracking(int ticketNum, vector& res){
        if(res.size() == ticketNum + 1){
            return true;
        }
        for(pair& target : targets[res[res.size()-1]]){
            if(target.second > 0){
                res.push_back(target.first);
                target.second--;
                if(backtracking(ticketNum, res)) return true;
                res.pop_back();
                target.second++;
            }
        }
        return false;
    }
    vector findItinerary(vector>& tickets) {
        targets.clear();
        vector res;
        for(const vector& vec : tickets){
            targets[vec[0]][vec[1]]++;
        }
        res.push_back("JFK");
        backtracking(tickets.size(), res);
        return res;
    }
};

二、(leetcode 51)N皇后

力扣题目链接

状态:抄代码。

class Solution {
public:
    vector> res;
    bool isValid(int row, int col, vector& chessboard, int n){
        // 检查行
        for(int i = 0; i < row; ++i){
            if(chessboard[i][col] == 'Q'){
                return false;
            }
        }
 
        // 检查45度角
        for(int i = row - 1, j = col-1; i >= 0 && j >= 0; --i, --j){
            if(chessboard[i][j] == 'Q'){
                return false;
            }
        }
 
        // 检查135度角
        for(int i = row - 1, j = col+1; i >= 0 && j < n; --i, ++j){
            if(chessboard[i][j] == 'Q'){
                return false;
            }
        }
        return true;
    }
    void backtracking(int n, int row, vector& chessboard){
        if(row == n){
            res.emplace_back(chessboard);
            return;
        }
        for(int col = 0; col < n; ++col){
            if(isValid(row, col, chessboard, n)){
                chessboard[row][col] = 'Q';
                backtracking(n, row+1, chessboard);
                chessboard[row][col] = '.';
            }
        }
    }
    vector> solveNQueens(int n) {
        res.clear();
        vector chessboard(n, string(n, '.'));
        backtracking(n, 0, chessboard);
        return res;
    }
};

三、(leetcode 37)解数独

力扣题目链接

状态:抄代码。

class Solution {
private:
bool backtracking(vector>& board) {
    for (int i = 0; i < board.size(); i++) {        // 遍历行
        for (int j = 0; j < board[0].size(); j++) { // 遍历列
            if (board[i][j] == '.') {
                for (char k = '1'; k <= '9'; k++) {     // (i, j) 这个位置放k是否合适
                    if (isValid(i, j, k, board)) {
                        board[i][j] = k;                // 放置k
                        if (backtracking(board)) return true; // 如果找到合适一组立刻返回
                        board[i][j] = '.';              // 回溯,撤销k
                    }
                }
                return false;  // 9个数都试完了,都不行,那么就返回false
            }
        }
    }
    return true; // 遍历完没有返回false,说明找到了合适棋盘位置了
}
bool isValid(int row, int col, char val, vector>& board) {
    for (int i = 0; i < 9; i++) { // 判断行里是否重复
        if (board[row][i] == val) {
            return false;
        }
    }
    for (int j = 0; j < 9; j++) { // 判断列里是否重复
        if (board[j][col] == val) {
            return false;
        }
    }
    int startRow = (row / 3) * 3;
    int startCol = (col / 3) * 3;
    for (int i = startRow; i < startRow + 3; i++) { // 判断9方格里是否重复
        for (int j = startCol; j < startCol + 3; j++) {
            if (board[i][j] == val ) {
                return false;
            }
        }
    }
    return true;
}
public:
    void solveSudoku(vector>& board) {
        backtracking(board);
    }
};

你可能感兴趣的:(代码随想录二刷,算法)