题目链接

https://www.patest.cn/contests/pat-a-practise/1128

思路

可以 对每一个皇后 都判断一下 它的 行,列 ,左右对角线上 有没有皇后

深搜解决

但是这样太麻烦

其实我们可以想到

要符合要求的摆放

就是做到 每一行 每一列 每一条对角线 上 都是只有一个皇后的

每一行 就不用判断了

然后可以用 map 标记 该列 该对角线上 是否是已经有皇后的

如果已经有 那么就flag = 0

如果没有 就标记

然后 左对角线 上的特点就是 每个元素的 j - i 是相等的

右对角线上的特点是 i + j 是相等的

AC代码

#include <cstdio>
#include <cstring>
#include <ctype.h>
#include <cstdlib>
#include <cmath>
#include <climits>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <map>
#include <stack>
#include <set>
#include <numeric>
#include <sstream>
#include <iomanip>
#include <limits> #define CLR(a) memset(a, 0, sizeof(a))
#define pb push_back using namespace std;
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
typedef pair <int, int> pii;
typedef pair <ll, ll> pll;
typedef pair<string, int> psi;
typedef pair<string, string> pss; const double PI = 3.14159265358979323846264338327;
const double E = exp(1);
const double eps = 1e-30; const int INF = 0x3f3f3f3f;
const int maxn = 1e5 + 5;
const int MOD = 1e9 + 7; int main()
{
int t;
cin >> t;
while (t--)
{
int n, num;
int flag = 1;
cin >> n;
map <int, int> l, m, r;
for (int i = 1; i <= n; i++)
{
scanf("%d", &num);
if (m[num] || l[num - i] || r[num + i])
flag = 0;
m[num] = 1;
l[num - i] = 1;
r[num + i] = 1;
}
if (flag)
printf("YES\n");
else
printf("NO\n");
} }

最新文章

  1. python返回值与局部全局变量
  2. sql server 去除(替换)空格,回车,换行 函数
  3. LeetCode 168. Excel Sheet Column Title
  4. 利用navigator对象在浏览器中检查插件
  5. Hibernate之Annotation(注解的方式,非映射)
  6. ssm maven项目启动 报SYSTEM_PROPERTIES_MODE_ENVIRONMENT
  7. jQuery 扩展功能
  8. USB 2.0 Spec 微缩版
  9. 【阿里云产品公测】在Laravel4框架中使用阿里云OCS缓存
  10. js模块化开发
  11. 团体程序设计天梯赛-练习集L1-015. 跟奥巴马一起画方块
  12. 《C++游戏开发》笔记十四 平滑过渡的战争迷雾(二) 实现:真正的迷雾来了
  13. 当MVC4无法跳转时
  14. Mysql 连接查询 Mysql支持的连接查询有哪些
  15. vba读文本如果文本文件太大会提示错误!
  16. Java通过ftp上传文件
  17. java拦截器(Interceptor)学习笔记
  18. Sequence在Oracle中的使用
  19. 倒计时特效的CountAnimationLabel
  20. MongoDb企业应用实战(一) 写在MongoDb应用介绍之前(i)

热门文章

  1. 在Android中实现阴影效果
  2. 防止sql注入和跨站脚本攻击,跨站请求伪造以及一句话木马的学习记录
  3. postman+newman+jenkins环境部署
  4. 导出txt格式的说明书
  5. java移位运算符详解
  6. 完好用户体验: 活用window.location与window.open解决页面跳转问题
  7. erlang中的图片下载
  8. Oracle -- Create User
  9. 最新精品 强势来袭 XP,32/64位Win7,32/64位Win10系统【电脑城版】
  10. 导出到Excel中NPOI