A - Square Inequality

水题

B - Intersection

水题,就是找公共区间,维护一下 Lmax,Rmin即可

void solve() {
int n, a, b;
int maxa = -1, minb = 0x3f3f3f3f;
cin >> n;
for (int i = 0; i < n; ++i) {
cin >> a;
maxa = max(maxa, a);
}
for (int i = 0; i < n; ++i) {
cin >> b;
minb = min(minb, b);
}
cout << (minb - maxa + 1 > 0 ? minb - maxa + 1 : 0);
}

C - IPFL

交换两个或者把前一半和后一半交换,求 \(m\) 次变换后的结果。

模拟会T,把字符串前后两个分开存,然后进行操作

void solve() {
string s, x, y;
int n, q, a, b, op;
cin >> n >> s >> q;
x = s.substr(0, n), y = s.substr(n, n);
while (q--) {
cin >> op >> a >> b;
if (op == 2) swap(x, y);
else {
a--, b--;
if (a > b) swap(a, b);
if (b < n) swap(x[a], x[b]);
else if (a >= n)
swap(y[a - n], y[b - n]);
else
swap(x[a], y[b - n]);
}
}
cout << x << y;
}

D - RGB Coloring 2

\(n\) 个点 \(m\) 条边的无向图,求用三种颜色染色后每条边相连的点不同的图有几种。

一看数据范围显然是一个搜索题,不过直接搜索会有一些问题,因为先搜到哪个的不同可能图染色后是相同的,会造成重复,既然如此,那我们随便指定一个顺序就可以了。

using ll    = long long;
const int N = 30;
vector<int> e[N], a;
int col[N], v[N][4];
ll ans = 1, cur;
bool vis[N];
void dfs0(int x) {
a.push_back(x);
vis[x] = true;
for (int &y : e[x])
if (!vis[y]) dfs0(y);
}
void dfs(int x) {
if (x == a.size()) {
cur++;
return;
}
for (int i = 1; i <= 3; ++i) {
if (!v[a[x]][i]) {
for (int &y : e[a[x]])
if (!v[y][i]) v[y][i] = a[x];
dfs(x + 1);
for (int &y : e[a[x]])
if (v[y][i] == a[x]) v[y][i] = 0;
}
}
}
void solve() {
int n, m;
cin >> n >> m;
for (int i = 0, u, v; i < m; ++i) {
cin >> u >> v;
e[u].push_back(v);
e[v].push_back(u);
}
for (int i = 1; i <= n; ++i) {
if (!vis[i]) {
cur = 0;
a.resize(0);
dfs0(i);
for (int &y : e[i])
if (!v[y][1]) v[y][1] = i;
dfs(1);
ans = ans * cur * 3;
}
}
cout << ans << "\n";
}

E - Permutation 状压DP

借用一下 Acfboy 的思路

// Murabito-B 21/04/26
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 20;
struct node {
int x, y, z;
bool operator<(node b) const { return x < b.x; }
} a[N];
int n, m, L[N], R[N], g[N], f[(1 << 19) + 5];
bool flag[(1 << 19) + 5];
int popcount(int x) { return x == 0 ? 0 : popcount(x & (x - 1)) + 1; }
void solve() {
cin >> n >> m;
for (int i = 1; i <= m; ++i) cin >> a[i].x >> a[i].y >> a[i].z;
sort(a + 1, a + 1 + m);
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) {
if (a[j].x == i) {
L[i] = j;
break;
}
}
for (int j = m; j > 0; --j) {
if (a[j].x == i) {
R[i] = j;
break;
}
}
} for (int S = 1; S < (1 << n); ++S) {
flag[S] = true;
int k = popcount(S);
if (L[k] == 0) continue;
for (int i = 1; i <= n; ++i) g[i] = 0;
for (int i = 1, j = 1; i <= k; ++i) {
while ((S & (1 << j)) == 0) j++;
for (int l = j; l <= n; ++l) g[l]++;
j++;
} for (int i = L[k]; i <= R[k]; ++i)
flag[S] &= (g[a[i].y] <= a[i].z);
}
f[0] = 1;
for (int S = 0; S < (1 << n); ++S)
for (int i = 0; i <= 18; ++i)
if (((S & (1 << i)) == 0) && flag[S | (1 << i)]) f[S | (1 << i)] += f[S];
cout << f[(1 << n) - 1];
}
signed main() {
ios_base::sync_with_stdio(false), cin.tie(0), cout.tie(0);
solve();
}

AtCoder Beginner Contest 199 游记(AB水题,C字符串操作,D搜索,E状压)的更多相关文章

  1. AtCoder Beginner Contest 084(AB)

    A - New Year 题目链接:https://abc084.contest.atcoder.jp/tasks/abc084_a Time limit : 2sec / Memory limit  ...

  2. AtCoder Beginner Contest 083 (AB)

    A - Libra 题目链接:https://abc083.contest.atcoder.jp/tasks/abc083_a Time limit : 2sec / Memory limit : 2 ...

  3. AtCoder Beginner Contest 188 F - +1-1x2 思维题

    题目描述 给你两个数 \(x\),\(y\) 可以对 \(x\) 进行 \(+1,-1\) 或 \(\times 2\) 的操作 问最少操作多少次后变为 \(y\) \(x,y \leq 10^{18 ...

  4. AtCoder Beginner Contest 137 F

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

  5. AtCoder Beginner Contest 068 ABCD题

    A - ABCxxx Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement This contes ...

  6. AtCoder Beginner Contest 053 ABCD题

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

  7. AtCoder Beginner Contest 223

    AtCoder Beginner Contest 223 A是纯纯的水题,就不说了 B - String Shifting 思路分析 我真的sb,一开始想了好久是不是和全排列有关,然后读了好几遍题目也 ...

  8. KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解

    KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...

  9. AtCoder Beginner Contest 184 题解

    AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...

  10. AtCoder Beginner Contest 100 2018/06/16

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

随机推荐

  1. Tech Lead 要学会戴着镣铐跳舞

    这不是一篇讨喜的文章,至少不会是你常常看到的例如<成为优秀 Tech Lead 的六个建议>令人欢欣鼓舞的那一类.今天我们聊聊 Tech Lead 所面临的不那么轻松的现实问题 程序员一定 ...

  2. 文心一言 VS 讯飞星火 VS chatgpt (153)-- 算法导论12.2 9题

    九.用go语言,设 T 是一棵二叉搜索树,其关键字互不相同;设 x 是一个叶结点,y 为其父结点.证明: y.key 或者是 T 树中大于 x.key 的最小关键字,或者是 T 树中小于 x.key ...

  3. skywalking自定义插件开发

    skywalking是使用字节码操作技术和AOP概念拦截Java类方法的方式来追踪链路的,由于skywalking已经打包了字节码操作技术和链路追踪的上下文传播,因此只需定义拦截点即可. 这里以sky ...

  4. Selenium-无头模式headless

    无头模式适合的场景: 部署到没有gui界面的服务器,比如linux 开发环境测试完全没问题后可以使用无头模式,提高selenium速度. # 使用headless无界面浏览器模式 chrome_opt ...

  5. postman——请求与相应

    一.新建一个项目 直接点击左边栏上面的添加目录图标来新增一个根目录,这样就等于新建了一个项目,我们可以把一个项目或一个模块的用例都存放在这个目录之下,并且在根目录之下我们还可以在建立子目录来进行功能用 ...

  6. ElasticSearch之cat nodeattrs API

    命令样例如下: curl -X GET "https://localhost:9200/_cat/nodeattrs?v=true&pretty" --cacert $ES ...

  7. [BUG]自定义登录引发的配置加载问题-bugspringsecurity

    title: [BUG]自定义登录引发的配置加载问题 date: 2021-12-10 16:43:36.311 updated: 2021-12-27 19:10:16.773 url: https ...

  8. 【难受】SpirngCloud-Alibaba-nacos跨服务器访问接口的问题

    原想法:我首先准备了 一个网关 2个服务 分别将两个服务部署到不同的远程服务器当中 实现跨服务器访问接口 网关为本地调用--这里就不一一介绍了 问题 利用gateway做路由时出现服务不可用的情况,看 ...

  9. 2.elasticsearch中的mapping

    mapping 顾名思义,代表了映射关系.是文档中字段和数据类型的映射关系 为什么要了解mapping 虽然elasticsearch中已尽有的动态mapping(Dynamic Mapping),而 ...

  10. k8s 标签-2

    目录 标签-2 node的角色 修改node节点的角色,将他的角色修改成他的主机名 标签的作用 Cordon,Drain以及污点 Cordon--告警警戒 Drain 驱逐演示 污点 污点的Cordo ...