A. Not Too Hard

模拟。

Code

B. 11/11

模拟。

Code

C. Consecutive

Description

给你一个字符串 \(S\),有 \(Q\) 次询问,每次输入 \(l, r\),求:\([S_l,S_r]\) 区间中有多少个相邻的字符是相等的。

Solution

循环一遍字符串,看看 \(s_i\) 是否等于 \(s_{i+1}\),如果等于,记录前缀和数组 \(pre\),\(pre_i = pre_{i-1} + 1\),否则 \(pre_i = pre_{i-1}\)。

每次询问的时候只需要输出 \(pre_{r - 1} - pre_{l - 1}\) 即可。

Code
#include <bits/stdc++.h>

using namespace std;
const int N = 3e5 + 10; int n, t, l, r, len, c[N];
char s[N]; inline void solve() {
scanf("%d%d", &l, &r);
printf("%d\n", c[r - 1] - c[l - 1]);
} signed main() {
scanf("%d%d%s", &n, &t, s + 1);
for (int i = 1; i <= n; i++) c[i] = c[i - 1] + (s[i] == s[i + 1]);
while (t--) solve();
return 0;
}

D. Take ABC

Description

给定一个字符串 \(S\),每次会将字符串 \(S\) 中的一个子串 \(\texttt{ABC}\) 删除,进行若干次操作之后,输出字符串 \(S\)。

Solution

我们维护两个数组 \(nxt,lst\),分别表示每个字符的后面和前面字符的下标,类似于链表的思想。

维护变量 \(z\) 表示当前的下标,当 z != n + 1 的时候进行循环。

每次维护变量 \(t2,t3\) 分别赋值为 nxt[z]nxt[nxt[z]],表示下标 \(z\) 的下一个字符的下标和下一个字符的下一个字符的下标。

如果这三个下标分别对应的字符正好为 \(\texttt{ABC}\),则将 lst[nxt[t3]] 的值更改为 lst[z]nxt[lst[z]] 的值更改为 nxt[t3],表示删除了当前子串。并且将 \(z\) 指向 lst[z]

每次循环时 z = nxt[z] 即可。

时间复杂度近似于 \(O(n)\)。

Code
#include <bits/stdc++.h>

using namespace std;

const int N = 2e5 + 10;

int nxt[N], lst[N], v[N], n;
char s[N]; int main() {
scanf("%s", s + 1);
n = strlen(s + 1);
nxt[0] = 1;
lst[n + 1] = n;
for (int i = 1; i <= n; i++)
nxt[i] = i + 1, lst[i] = i - 1, v[i] = s[i] - 'A' + 1; // 将 nxt 数组和 lst 数组赋初始值,并且 v 数组记录将字符转换为数字的结果,方便判断
int z = 1, t2, t3;
while (z != n + 1) {
t2 = nxt[z];
t3 = nxt[t2];
if (t2 == n + 1 || t3 == n + 1) break; // 子串不存在,越界了
if (v[z] == 1 && v[t2] == 2 && v[t3] == 3) { // 找到子串 "ABC"
lst[nxt[t3]] = lst[z];
nxt[lst[z]] = nxt[t3];
// 如果下标存在,就指向前一个字符
if (z) z = lst[z];
if (z) z = lst[z];
if (z) z = lst[z];
}
z = nxt[z];
}
// 打印结果
z = nxt[0];
while (z != n + 1)
printf("%c", 'A' - 1 + v[z]), z = nxt[z];
return 0;
}

E. Modulo MST

Description

给你一个无向图,求:生成树中最小的路径,最小路径的定义为路径上的每条边权值之和 \(\bmod \ K\) 的结果。

Solution

这道题不能用最小生成树的思想来做,因为加了一个取模的条件,所以不能贪心地取最小的路径。

所以看到数据范围 \(1 \le N \le 8,1 \le M \le \dfrac{N(N-1)}{2}\),很明显可以爆搜。

如果遍历每条边,\(M\) 最大为 \(28\),最多有 \(C_{28}^{8}\) 种可能性,大概为 \(10 ^ 6\) 左右,总的时间复杂度为 \(O(C_{28}^{8} \times \log n)\),不会超时。

但是要注意剪枝,可以使用按秩合并的并查集来做,注意不要路径压缩,这样的话就无法在搜索时回溯。

Code
#include <bits/stdc++.h>
#define int long long using namespace std; const int N = 20;
int n, m, k, fa[N], si[N];
int x[N << 1], y[N << 1], len[N << 1]; int find(int x) {
return x == fa[x] ? x : find(fa[x]);
} int dfs(int i, int cnt, int sum) {
if (i == m + 1) {
if (cnt == n - 1) return sum;
return 1e18;
}
int rx = find(x[i]), ry = find(y[i]);
if (rx == ry) return dfs(i + 1, cnt, sum);
if (si[rx] > si[ry]) swap(rx, ry);
fa[rx] = ry;
si[rx] += si[ry];
int ans = dfs(i + 1, cnt + 1, (sum + len[i]) % k);
fa[rx] = rx;
si[rx] -= si[ry];
ans = min(ans, dfs(i + 1, cnt, sum));
return ans;
} signed main() {
cin >> n >> m >> k;
for (int i = 1; i <= n; i++) fa[i] = i, si[i] = 1;
for (int i = 1; i <= m; i++) cin >> x[i] >> y[i] >> len[i];
cout << dfs(1, 0, 0);
return 0;
}

AtCoder Beginner Contest 328 (ABC328)的更多相关文章

  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. JSONP前端流程

    JSONP前端流程 JSONP总体思路 后端先给前端一个接口文档. 如https://www.baidu.com/sugrec?prod=pc&wd=用户输入的文字&cb=后端要调用的 ...

  2. Unity的IPreprocessShaders:深入解析与实用案例

    Unity IPreprocessShaders Unity IPreprocessShaders是Unity引擎中的一个非常有用的功能,它可以让开发者在编译Shader时自定义哪些操作需要被执行.这 ...

  3. 论文解读(Moka‑ADA)《Moka‑ADA: adversarial domain adaptation with model‑oriented knowledge adaptation for cross‑domain sentiment analysis》

    Note:[ wechat:Y466551 | 可加勿骚扰,付费咨询 ] 论文信息 论文标题:Moka‑ADA: adversarial domain adaptation  with model‑o ...

  4. 【腾讯云 Cloud Studio 实战训练营】提升开发效率与协作:探索腾讯云 Cloud Studio 的强大功能与优势

    一.前言 前几天发生了一个故事,发生了这样一个情景:一位新加入的同事刚刚入职不久,领取了一台崭新的电脑.随后,他投身于一个新项目,但却遇到了一个困扰:由于这台电脑没有管理员权限,他无法在上面安装所需的 ...

  5. 原生CSS嵌套简介

    嵌套是使用Sass等CSS预处理器的核心原因之一.现在,该功能已经以类似的语法出现在标准浏览器CSS中.你能否在构建系统时放弃对预处理器的依赖? CSS嵌套可以节省输入时间,并使语法更易于阅读和维护. ...

  6. VS2015项目.net-framework-4.5.2升级或新建项目无法选择framework 4.6.2(解决办法)

    VS2015里面没有.NET Framework 4.6.2 VS2015默认安装的目标框架最高是.NET Framework 4.6.1,但是我的项目里面某些NuGet软件包更新需要依赖.NET F ...

  7. 头疼!卷积神经网络是什么?CNN结构、训练与优化一文全解

    本文全面探讨了卷积神经网络CNN,深入分析了背景和重要性.定义与层次介绍.训练与优化,详细分析了其卷积层.激活函数.池化层.归一化层,最后列出其训练与优化的多项关键技术:训练集准备与增强.损失函数.优 ...

  8. 智能AI 的应用场景

    小凡智能AI是一款基于人工智能技术开发的助软件,能够帮助用户解决各种各样的问题,提高工作效率和生活质量.它的应用范围广泛,涵盖了工作.学习.健康等多个方面,为用户提供了全方位的服务支持. 在工作方面, ...

  9. Redis沙盒逃逸(CVE-2022-0543)漏洞复现

    0x01 概述 Redis 是著名的开源 Key-Value 数据库,其具备在沙箱中执行 Lua 脚本的能力.Debian 以及 Ubuntu 发行版的源在打包 Redis 时,在 Lua 沙箱中遗留 ...

  10. Solidity-变量和数据类型[复合类型_1]

    复合类型的数据包括:array(数组).struct(结构体)和mapping(映射),其中array和struct也称为引用类型. 复合类型 数组(array) 数组(array)是一种用于存储相同 ...