比赛链接:Here

A - Weather Forecas

水题,判断 \(s[n - 1] = o\) 的话输出 YES

B - qwerty

题意:给出 \((1,2,...,26)\) 的某个全排列 \(p\) ,请对于 \(1\le i \le 26\) 的每个 \(p_i\) ,输出第 \(p_i\) 个小写字母

void solve() {
int n = 26;
for (int i = 0, x; i < n; ++i) {
cin >> x;
cout << char('a' + x - 1);
}
}

C - Shapes

题意:在 \(n\times n\) 的二维空间中有 \(S,T\) 两个图形,问能否经过任意次旋转 \(90°\) 和平移操作,使两图形相等?

数据范围:\(1\le N\le 200\)

思路:

可以把 \(S\)​​ 和三种旋转出来的图形的 \(\#\)​​ 的坐标分别存在 \(4\)​​ 个 \(vector\)​ 里 然后 \(x\)​ 优先 \(y\)​ 次优先排个序

然后把 \(T\)​ 的所有 \(\#\)​ 的坐标也放到 \(vector\)​ 里排序

因为要是 yes 的话 \(T\)​ 肯定是 \(S\)​ 的 \(4\)​ 个 \(vector\) 中的其中一个 \(vector\) 平移出来的

那枚举每个 \(S\) 的 \(vector\) 和 \(T\) 的 \(vector\) 每个点的 \(x\) 都相减 如果得出来的值都一样

再把 \(y\) 也做同样操作 如果也相同 那么就是平移出来的就是 yes ,如果旋转出来的所有情况都无法平移到 \(T\) 就输出No

struct node {int x, y;};
vector<node>v1, v2, v3, v4, v5;
bool cmp(node a, node b) { return a.x == b.x ? a.y < b.y : a.x < b.x; }
bool check(vector<node> a, vector<node>b) {
int n = a.size();
int lx = a[0].x - b[0].x;
int ly = a[0].y - b[0].y;
for (int i = 0; i < n; i++) {
if (a[i].x - b[i].x != lx) return false;
if (a[i].y - b[i].y != ly) return false;
}
return true;
}
void solve() {
int n; cin >> n;
for (int i = 1; i <= n; ++i)
for (int j = 1; j <= n; ++j) {
char c; cin >> c;
if (c == '#') {
v1.push_back({i, j});
v2.push_back({j, n - i + 1});
v3.push_back({n - j + 1, i});
v5.push_back({n - i + 1, n - j + 1});
}
}
for (int i = 1; i <= n; ++i)
for (int j = 1; j <= n; ++j) {
char c; cin >> c;
if (c == '#')
v4.push_back({i, j});
}
if (v1.size() != v4.size()) {cout << "No\n"; return ;}
if (v1.size() == 0 and v2.size() == 0) {cout << "Yes\n"; return ;}
sort(v1.begin(), v1.end(), cmp);
sort(v2.begin(), v2.end(), cmp);
sort(v3.begin(), v3.end(), cmp);
sort(v4.begin(), v4.end(), cmp);
sort(v5.begin(), v5.end(), cmp);
int f = 0;
if (check(v1, v4)) f = 1;
if (check(v2, v4)) f = 1;
if (check(v3, v4)) f = 1;
if (check(v5, v4)) f = 1;
cout << (f ? "Yes\n" : "No\n");
}

D - Rectangles

题意:已知二维平面上 \(n\le 2000\) 个点,求能构成边平行于坐标轴的矩形的个数。

数据范围:\(0\le x_i,y_i\le 1e9,(x_i,y_i) \not=(x_j,y_j)(i\not=j)\)

思路:枚举两个点作为矩形的对角线,并检查另外两个点是否也在平面上。

这样一来,一个矩形会被计算两次(两条对角线),所以答案要除以 \(2\)。

struct node {
int x, y;
bool operator <(const node &nd) const {
if (x == nd.x) return y < nd.y;
else return x < nd.x;
}
};
void solve() {
int n; cin >> n;
int x[n + 1], y[n + 1];
map<node, int>mp;
for (int i = 1; i <= n; i++)
cin >> x[i] >> y[i], mp[(node) {x[i], y[i]}] = 1; //记录节点
ll cnt = 0;
for (int i = 1; i <= n; ++i)
for (int j = i + 1; j <= n; ++j) {
if (x[i] == x[j] || y[i] == y[j]) continue;
if (mp[(node) {x[i], y[j]}] == 1 and mp[(node) {x[j], y[i]}] == 1) cnt += 1;
}
cout << cnt / 2 << "\n";
}

EFG待补

AtCoder Beginner Contest 218 A~D的更多相关文章

  1. AtCoder Beginner Contest 100 2018/06/16

    A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...

  2. AtCoder Beginner Contest 052

    没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...

  3. AtCoder Beginner Contest 053 ABCD题

    A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...

  4. AtCoder Beginner Contest 136

    AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...

  5. AtCoder Beginner Contest 137 F

    AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...

  6. AtCoder Beginner Contest 076

    A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...

  7. AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】

    AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...

  8. AtCoder Beginner Contest 064 D - Insertion

    AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...

  9. AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle【暴力】

    AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...

  10. AtCoder Beginner Contest 075 C bridge【图论求桥】

    AtCoder Beginner Contest 075 C bridge 桥就是指图中这样的边,删除它以后整个图不连通.本题就是求桥个数的裸题. dfn[u]指在dfs中搜索到u节点的次序值,low ...

随机推荐

  1. Windows10+Python+Yolov8+ONNX图片缺陷识别,并在原图中标记缺陷,有onnx模型则无需配置,无需训练。

    目录 一.训练自己数据集的YOLOv8模型 1.博主电脑配置 2.深度学习GPU环境配置 3.yolov8深度学习环境准备 4.准备数据集 二.Python+Onnx模型进行图像缺陷检测,并在原图中标 ...

  2. 龙芯发布 .NET 8 SDK 8.0.100-ea1(试用版)

    随着.NET 8的发布,国内的社区朋友们也很关心龙芯.NET 团队对于Loongarch .NET 8的发布时间,目前从龙芯.NET编译器团队已经在龙芯.NET 官网上发布龙芯.NET 8 SDK-8 ...

  3. Vue2.0 学习 第三组 条件语句

    本笔记主要参考菜鸟教程和官方文档编写.1.v-if在div或者之类的dom中使用v-if可以控制是否插入该dom,控制由v-if的true和false决定.如:<div id="app ...

  4. yarn的常用命令

    yarn 安装 npm install -g yarn 查看版本 yarn -v 开始一个新工程 yarn init 与 npm init 一样通过交互式会话创建一个 package.json yar ...

  5. Linux查看内存使用情况以及释放内存

    查看内存使用情况 一般使用 top 命令即可,命令行输入 top会实时显示内存和cpu等硬件的使用情况,然后输入M即显示内存的使用情况. 但是有些情况下,内存明明被占用了,但是使用top命令依然无法找 ...

  6. 使用jvm工具排查系统问题

    java-jvm-tool Jstatd 远程连接(推荐) 不用重启项目 远程机配置 [demo@localhost jvmtest]$ vi jstatd.all.policy# 内容grant c ...

  7. Java使用HttpUtil.request方法可以发送请求即【Java访问url得到响应数据】

    Java使用HttpUtil.request方法可以发送请求即[Java访问url得到响应数据] 注:这个工具类可以在网上找,也可以自己手写 ,手写的话需要用到以下依赖: <dependency ...

  8. 【并发编程特性】并发编程特性之五种特性的探讨-volatileandsynchronized

    title: [并发编程特性]并发编程特性之五种特性的探讨 date: 2021-11-18 10:16:05.492 updated: 2021-12-26 17:43:10.414 url: ht ...

  9. Python——第二章:字符串操作——总结

    总结: f"{变量}"  格式化字符串最优方法 索引.切片.步长: 索引:从0开始计算的.[5] 切片:s[start: end: step],end位置的数据永远拿不到,左闭又开 ...

  10. 告别复杂排版:Markdown语法指南

    导语:Markdown作为一种轻量级的标记语言,以其简洁.易学的语法和强大的兼容性赢得了广泛的应用.本文将为您详细介绍Markdown的起源.基本语法及其在写作.博客.项目管理等场景的应用,带您领略这 ...