Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
138363 | | N皇后问题 | C++ | 运行超时 | 80 | 1000 MS | 248 KB | 728 | 2024-03-16 08:40:03 |
#include <bits/stdc++.h> using namespace std; int ans; bool is(const vector<int>& b, int r, int c) { int n = b.size(); for (int i = 0; i < r; ++i) { if (b[i] == c || abs(i - r) == abs(b[i] - c)) { return false; } } return true; } void solve(vector<int>& b, int r) { int n = b.size(); if (r == n) { ans++; return; } for (int c = 0; c < n; ++c) { if (is(b, r, c)) { b[r] = c; solve(b, r + 1); b[r] = -1; } } } void nQ(int n) { vector<int> b(n, -1); solve(b, 0); } int main() { int n; cin >> n; nQ(n); cout<<ans; return 0; }