比赛链接:Here

AcWing 3811. 排列

签到题,

先输出 \(n\) 然后输出 \(1\sim n -1\) 即可

AcWing 3812. 机器人走迷宫

不会什么特别高级的方法 qaq,只能全排列 + bfs(懒得写太长了,注释写代码里 qaq)

#include <bits/stdc++.h>
#define rep(a,b,c) for (int i = a; i <= b; i += c)
#define rept(i,a,b,c) for (int i = a; i <= b; i += c) using namespace std; const int N = 1e3 + 5, INF = INFINITY;
int n, m, a[N][N];
string st; int sx, sy, fx, fy; void init () {
cin >> n >> m;
rep (1, n, 1) rept (j, 1, m, 1) {
char ch; cin >> ch;
a[i][j] = (ch == '#');
if (ch == 'S') sx = i, sy = j;
if (ch == 'E') fx = i, fy = j; // 起点 终点
}
cin >> st;
} int mx[] = {0, 0, -1, 1}, my[] = {-1, 1, 0, 0}, mtx[50]; // mtx 表示对应 0~3 的分配 struct Node { int x, y, step; }; bool bfs () { // 广搜模板不需要太多解释
queue<Node> q;
q.push ({sx, sy, 0});
while (!q.empty()) {
Node tp = q.front(); q.pop();
int x = tp.x, y = tp.y, sp = tp.step;
if (x == fx && y == fy && sp <= st.size()) return 1;
int M = mtx[st[sp] & 15]; // 位运算,等价于 M = mtx[st[sp] - 48]
x += mx[M], y += my[M], sp ++;
if (!(x && y && x <= n && y <= m && !a[x][y])) return 0;// 如果撞墙/越界就送走(
q.push ({x, y, sp});
}
return 0;
} void solve() {
mtx[0] = 0; mtx[1] = 1; mtx[2] = 2; mtx[3] = 3;
int res = 0;
do res += bfs(); /*可以到达终点 方案 + 1*/ while (next_permutation (mtx, mtx + 4)); // 全排列
printf ("%d\n", res);
return ;
} int main() {
int T; cin >> T;
while (T --) init(), solve();
return 0;
}

AcWing 3813. 最大路径权值

拆点 + topsort

拆点: \(dist[N][26]\) 把每个点拆成 \(26\) 个点, 分别表示到当前点的路径上, 每个字母的最大值

topsort:找环, 判掉有环的情况, 我们可以发现, 无论最长路径的字母是哪个字母, 我们都可以从该路径对应的拓扑序的第一个点开始遍历, 所以只要按照拓扑序线性递推就行了

const int N = 3e5 + 10, M = 5e5;
int h[N], e[M], ne[M], idx;
int dist[N][30];
int d[N];
typedef pair<int, int> PII;
int hh = 0, tt = -1;
bool st[N];
int q[N];
int w[N];
int n, m; void add(int a, int b) { // 添加一条边a->b
e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ;
} bool topsort() {
// d[i] 存储点i的入度
for (int i = 1; i <= n; i ++ )
if (!d[i])
q[ ++ tt] = i;
while (hh <= tt) {
int t = q[hh ++ ];
for (int i = h[t]; i != -1; i = ne[i]) {
int j = e[i];
if (-- d[j] == 0)
q[ ++ tt] = j;
}
} // 如果所有点都入队了,说明存在拓扑序列;否则不存在拓扑序列。
return tt == n - 1;
} int main() {
scanf("%d%d", &n, &m);
string tmp;
cin >> tmp;
memset(h, -1, sizeof h);
for (int i = 1; i <= n; i ++ ) {
int x = tmp[i - 1] - 'a';
w[i] = x;
}
while (m -- ) {
int a, b;
scanf("%d%d", &a, &b);
add(a, b);
d[b] ++;
}
for (int i = 1; i <= n; i ++ ) {
if (!d[i]) {
dist[i][w[i]] = 1;
}
}
bool flag = topsort();
if (!flag) {
puts("-1");
return 0;
}
for (int i = 0; i <= tt; i ++ ) {
int j = q[i];
for (int u = h[j]; ~u; u = ne[u]) {
int k = e[u];
for (int v = 0; v < 26; v ++ ) {
dist[k][v] = max(dist[k][v], dist[j][v] + (w[k] == v));
}
}
}
int ans = 0;
for (int i = 1; i <= n; i ++ ) {
for (int j = 0; j < 26; j ++ ) {
ans = max(ans, dist[i][j]);
}
}
printf("%d", ans);
return 0;
}

AcWing 第 13 场周赛  补题记录的更多相关文章

  1. 2018 HDU多校第四场赛后补题

    2018 HDU多校第四场赛后补题 自己学校出的毒瘤场..吃枣药丸 hdu中的题号是6332 - 6343. K. Expression in Memories 题意: 判断一个简化版的算术表达式是否 ...

  2. 2018 HDU多校第三场赛后补题

    2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...

  3. 【补题记录】ZJU-ICPC Summer Training 2020 部分补题记录

    补题地址:https://zjusummer.contest.codeforces.com/ Contents ZJU-ICPC Summer 2020 Contest 1 by Group A Pr ...

  4. 【春训团队赛第四场】补题 | MST上倍增 | LCA | DAG上最长路 | 思维 | 素数筛 | 找规律 | 计几 | 背包 | 并查集

    春训团队赛第四场 ID A B C D E F G H I J K L M AC O O O O O O O O O 补题 ? ? O O 传送门 题目链接(CF Gym102021) 题解链接(pd ...

  5. 【JOISC 2020 补题记录】

    目录 Day 1 Building 4 Hamburg Steak Sweeping Day 2 Chameleon's Love Making Friends on Joitter is Fun R ...

  6. AcWing第85场周赛

    这场周赛是手速局hh 死或生 某国正在以投票的方式决定 2 名死刑犯(编号 1∼2)的生死. 共有 n 组人员(编号 1∼n)参与投票,每组 10 人. 每组成员只参与一名死刑犯的投票,其中第 i 组 ...

  7. 【cf补题记录】Codeforces Round #608 (Div. 2)

    比赛传送门 再次改下写博客的格式,以锻炼自己码字能力 A. Suits 题意:有四种材料,第一套西装需要 \(a\).\(d\) 各一件,卖 \(e\) 块:第二套西装需要 \(b\).\(c\).\ ...

  8. 【cf补题记录】Codeforces Round #607 (Div. 2)

    比赛传送门 这里推荐一位dalao的博客-- https://www.cnblogs.com/KisekiPurin2019/ A:字符串 B:贪心 A // https://codeforces.c ...

  9. ZJUT11 多校赛补题记录

    牛客第一场 (通过)Integration (https://ac.nowcoder.com/acm/contest/881/B) (未补)Euclidean Distance (https://ac ...

  10. Codeforces 补题记录

    首先总结一下前段时间遇到过的一些有意思的题. Round #474 (Div. 1 + Div. 2, combined)   Problem G 其实关键就是n这个数在排列中的位置. 这样对于一个排 ...

随机推荐

  1. Java笔记——常用类

    一.API概述 JDK中提供的各种功能的Java类 二.Object类 概述 类层次结构的根类 所有类都直接或间接的继承自该类 Class Object是类object结构的根.每个Class都有ob ...

  2. 一个基于.NET Core开源、跨平台的仓储管理系统

    前言 今天给大家推荐一个基于.NET Core开源.跨平台的仓储管理系统,数据库支持MSSQL/MySQL:ZEQP.WMS. 仓储管理系统介绍 仓储管理系统(Warehouse Management ...

  3. 【Javaweb】关于html转成jsp时出现乱码的问题解决

    原因是没有在代码头部添加,下面这段代码,添加之后就解决了 <%@ page language="java" contentType="text/html; char ...

  4. Java八股面试整理(4)

    34.遇到过异常吗,如何处理? 在Java中,可以按照如下三个步骤处理异常: 捕获异常 将业务代码包裹在try块内部,当业务代码中发生任何异常时,系统都会为此异常创建一个异常对象.创建异常对象之后,J ...

  5. 🔥🔥Java开发者的Python快速实战指南:实用工具之PDF转DOCX文档(可视化界面)

    首先,大家对Python语法的了解已经基本完成,现在我们需要开始进行各种练习.我为大家准备了一些练习题目,比如之前的向量数据库等,这些题目可以参考第三方的SDK来进行操作,文档也是比较完善的.这个过程 ...

  6. 从0到1,手把手带你开发截图工具ScreenCap------003实现最小化程序到托盘运行

    ScreenCap---Version:003 说明 上一篇:实现默认位置设置 为了方便截图干净,实现最小化程序到托盘运行,简洁,勿扰 实现最小化程序到托盘运行 实现托盘菜单功能 实现回显主窗体 实现 ...

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

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

  8. Http请求超好用的工具类

    话题不多说,直接开整 1.先导入依赖 <dependency> <groupId>io.github.admin4j</groupId> <artifactI ...

  9. cgroup的入门资料

    近期在准备特性的设计文档,按照评审专家的建议,需要排查现有产品中算力资源比如CPU.内存的分配方案,确认现有的硬件款型是否具备充足的资源来启用本特性. 依据前辈提供的建议,检查了产品的部署脚本,发现当 ...

  10. 2023-12-30:用go语言,给你一个下标从 0 开始的整数数组 nums ,它包含 n 个 互不相同 的正整数, 如果 nums 的一个排列满足以下条件,我们称它是一个特别的排列。 对于 0 <

    2023-12-30:用go语言,给你一个下标从 0 开始的整数数组 nums ,它包含 n 个 互不相同 的正整数, 如果 nums 的一个排列满足以下条件,我们称它是一个特别的排列. 对于 0 & ...