Solution -「NOI 2017」「洛谷 P3825」游戏
\(\mathscr{Description}\)
Link.
给大家看个乐子: link, 懒得概括题意啦.
\(\mathscr{Solution}\)
对于没有 X 的情况, 显然可以 2-SAT; 对于有 X 的情况, 暴力枚举这辆车属于 \(\{X,A\}\) 还是 \(\{B,C\}\), 继续 2-SAT. 复杂度 \(\mathcal O(2^d(n+m))\).
\(\mathscr{Code}\)
/* Clearink */
#include <cstdio>
#include <cstdlib>
const int MAXN = 5e4, MAXM = 1e5;
int n, cx, m, xpos[10], xid[MAXN + 5];
char s[MAXN + 5];
inline void chkmin ( int& a, const int b ) { b < a && ( a = b, 0 ); }
inline int id ( const int sta, const int i, const int c ) {
if ( ~xid[i] ) {
if ( ( sta >> xid[i] ) & 1 ) return c ? -1 : 0;
if ( !c ) return -1;
return ( c + 2 ) % 3;
} else {
if ( s[i] == c ) return -1;
return ( c - s[i] + 2 ) % 3;
}
}
struct Restrict {
int u, a, v, b; // u use a -> v use b.
inline void read () {
char ta, tb;
scanf ( "%d %c %d %c", &u, &ta, &v, &tb ), a = ta - 'A', b = tb - 'A';
}
} restr[MAXM + 5];
struct TwoSAT {
static const int MAXND = MAXN << 1, MAXEG = MAXM << 1;
int ecnt, head[MAXND + 5], to[MAXEG + 5], nxt[MAXEG + 5];
int dfc, dfn[MAXND + 5], low[MAXND + 5], top, stk[MAXND + 5];
int scc, clr[MAXND + 5];
bool ins[MAXND + 5];
inline void clear () {
ecnt = scc = dfc = 0;
for ( int i = 1; i <= n << 1; ++i ) head[i] = dfn[i] = 0;
}
inline void link ( const int s, const int t ) {
to[++ecnt] = t, nxt[ecnt] = head[s];
head[s] = ecnt;
}
inline void Tarjan ( const int u ) {
int v;
dfn[u] = low[u] = ++dfc, ins[stk[++top] = u] = true;
for ( int i = head[u]; i; i = nxt[i] ) {
if ( !dfn[v = to[i]] ) Tarjan ( v ), chkmin ( low[u], low[v] );
else if ( ins[v] ) chkmin ( low[u], dfn[v] );
}
if ( dfn[u] == low[u] ) {
++scc;
do ins[v = stk[top--]] = false, clr[v] = scc; while ( u ^ v );
}
}
inline bool check ( const int sta ) {
for ( int i = 1; i <= n << 1; ++i ) if ( !dfn[i] ) Tarjan ( i );
for ( int i = 1; i <= n; ++i ) if ( clr[i] == clr[i + n] ) return false;
for ( int i = 1; i <= n; ++i ) {
bool val = clr[i] > clr[i + n];
if ( !~xid[i] ) putchar ( ( s[i] + 1 + val ) % 3 + 'A' );
else if ( !( ( sta >> xid[i] ) & 1 ) ) putchar ( 1 + val + 'A' );
else putchar ( 'A' );
}
return putchar ( '\n' ), exit ( 0 ), true;
}
inline void build ( const int sta ) {
clear ();
for ( int i = 0; i < cx; ++i ) {
if ( ( sta >> i ) & 1 ) {
link ( xpos[i] + n, xpos[i] ); // choose A only.
}
}
for ( int i = 1; i <= m; ++i ) {
int ia = id ( sta, restr[i].u, restr[i].a );
int ib = id ( sta, restr[i].v, restr[i].b );
if ( !~ia ) continue;
if ( !~ib ) link ( restr[i].u + ia * n, restr[i].u + ( ia ^ 1 ) * n );
else {
link ( restr[i].u + ia * n, restr[i].v + ib * n );
link ( restr[i].v + ( ib ^ 1 ) * n, restr[i].u + ( ia ^ 1 ) * n );
}
}
}
} sat;
int main () {
scanf ( "%d %d %s", &n, &cx, s + 1 );
for ( int i = 1, t = 0; i <= n; ++i ) {
if ( s[i] == 'x' ) {
xpos[xid[i] = t++] = i;
s[i] = '$';
} else s[i] -= 'a', xid[i] = -1;
}
scanf ( "%d", &m );
for ( int i = 1; i <= m; ++i ) restr[i].read ();
for ( int s = 0; s < 1 << cx; ++s ) {
sat.build ( s );
if ( sat.check ( s ) ) return 0;
}
puts ( "-1" );
return 0;
}
Solution -「NOI 2017」「洛谷 P3825」游戏的更多相关文章
- 洛谷 P3825 [NOI2017]游戏 【2-SAT+状压】
UOJ和洛谷上能A,bzoj 8ms即WA,现在也不是知道为啥--因为我太弱了 先看数据范围发现d非常小,自然想到了状压. 所以先假装都是只能跑两种车的,这显然就是个2-SAT问题了:对于x场没有hx ...
- 洛谷P3825 [NOI2017]游戏(2-SAT)
传送门 果然图论的题永远建图最麻烦……看着题解代码的建图过程真的很珂怕…… 先不考虑地图$x$,那么每一个地图都只能用两种赛车,于是我们可以用2-SAT来搞,用$i$表示这个地图能用的第一辆车,$i' ...
- 「区间DP」「洛谷P1043」数字游戏
「洛谷P1043」数字游戏 日后再写 代码 /*#!/bin/sh dir=$GEDIT_CURRENT_DOCUMENT_DIR name=$GEDIT_CURRENT_DOCUMENT_NAME ...
- [CodePlus 2017 11月赛&洛谷P4058]木材 题解(二分答案)
[CodePlus 2017 11月赛&洛谷P4058]木材 Description 有 n棵树,初始时每棵树的高度为 Hi ,第 i棵树每月都会长高 Ai.现在有个木料长度总量为 S的订单, ...
- 洛谷 P2197 nim游戏
洛谷 P2197 nim游戏 题目描述 甲,乙两个人玩Nim取石子游戏. nim游戏的规则是这样的:地上有n堆石子(每堆石子数量小于10000),每人每次可从任意一堆石子里取出任意多枚石子扔掉,可以取 ...
- 洛谷 P1965 转圈游戏
洛谷 P1965 转圈游戏 传送门 思路 每一轮第 0 号位置上的小伙伴顺时针走到第 m 号位置,第 1 号位置小伙伴走到第 m+1 号位置,--,依此类推,第n − m号位置上的小伙伴走到第 0 号 ...
- Solution -「JSOI 2019」「洛谷 P5334」节日庆典
\(\mathscr{Description}\) Link. 给定字符串 \(S\),求 \(S\) 的每个前缀的最小表示法起始下标(若有多个,取最小的). \(|S|\le3\time ...
- Solution -「洛谷 P4372」Out of Sorts P
\(\mathcal{Description}\) OurOJ & 洛谷 P4372(几乎一致) 设计一个排序算法,设现在对 \(\{a_n\}\) 中 \([l,r]\) 内的元素排 ...
- Solution -「POI 2010」「洛谷 P3511」MOS-Bridges
\(\mathcal{Description}\) Link.(洛谷上这翻译真的一言难尽呐. 给定一个 \(n\) 个点 \(m\) 条边的无向图,一条边 \((u,v,a,b)\) 表示从 ...
- Solution -「APIO 2016」「洛谷 P3643」划艇
\(\mathcal{Description}\) Link & 双倍经验. 给定 \(n\) 个区间 \([a_i,b_i)\)(注意原题是闭区间,这里只为方便后文描述),求 \(\ ...
随机推荐
- python面向对象复习
1.类的语法 # 类的语法 # 定义类 class Dog(object): # 类的属性或者类变量,一般是公共属性,存在类的内存空间,所有实例对象共享 d_type = "京巴" ...
- python操作pptx设置title字体大小插入全屏图片A4尺寸实例一枚
pip install python-pptx 安装好pptx,设置标题最大的作用是ppt里面的摘要视图显示摘要文字 参考:https://python-pptx.readthedocs.io/en/ ...
- 2024年全国大学生信息安全竞赛安徽省赛-WP
2024年全国大学生信息安全竞赛安徽省赛-WP 没有re,不会...... 0X01 初赛(CTF) MISC 图像损坏 损坏的GIF文件,补上缺失的文件头 用puzz拆分GIF,得到多个图片 ...
- 二元一次不定方程(Exgcd)(更方便的解法)
扩展欧几里得算法(Exgcd) 裴蜀定理 对于任意一组整数 \(a,b\),存在一组整数 \(x,y\),满足 \(ax+by=\gcd(a,b)\). Proof: 考虑数学归纳法. 当 \(b=0 ...
- 2021“MINIEYE杯”(1)
Start Time : 2021-07-20 12:10:00 End Time : 2021-07-20 17:10:00 1001-Mod, Or and Everything 真正的签到题 题 ...
- Nuxt.js 应用中的 webpackConfigs 事件钩子
title: Nuxt.js 应用中的 webpackConfigs 事件钩子 date: 2024/11/20 updated: 2024/11/20 author: cmdragon excerp ...
- K均值聚类和代码实现
K均值聚类是一种无监督学习分类算法. 介绍 对于$n$个$m$维特征的样本,K均值聚类是求解最优化问题: $\displaystyle C^*=\text{arg}\min\limits_{C}\su ...
- WiFi基础(八):WiFi安全、认证与加密
liwen01 2024.11.17 前言 计算机网络在给人们带来便利的同时,也引入了安全风险,对于无线WiFi网络而言,风险更高.无线 WiFi 网络安全主要包括两大部分:接入认证和数据加密. 虽然 ...
- Windows下驱动安装
推荐使用金山毒霸中的电脑医生进行驱动或DLL文件的扫描,查找并下载 dll文件下载地址: https://www.wenjian.net/ 可以进行下载,告诉该文件的放置路径 其他:
- 版本管理客户端工具SourceTree
[使用] 1.设置SSH客户端 工具 > 选项 设置OpenSSH, SSH 密钥这一栏自然会去选择当前用户下的 .ssh 目录下的 id_rsa 这个私钥: