热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CF1567FOneFourOverload

CF1567FOne-FourOverload我居然把这道\(2700\)的题切了!!!\(-OHHHHHHHHHHHHHHHH!!!\)没有标记的格子只能选\(1\)或者\(4\

CF1567F One-Four Overload

我居然把这道 \(2700\) 的题切了!!!

\(-OHHHHHHHHHHHHHHHH!!!\)

没有标记的格子只能选 \(1\) 或者 \(4\) , 标记的格子必须是 \(5\) 的倍数.

比较显然的是, 标记的格子周围必须有且只能有偶数个 (包括 \(0\) ) 未标记的格子, 否则无解.

接下来我们考虑构造一组解.

比较显然的是, 如果一个标记的格子周围只有两个未标记的格子, 那么一定是一个 \(1\) 一个 \(4\) , 不管是 \(L\) 形还是 \(I\) 形.

如果有 \(4\) 个呢? 那么我们就把同一行的和同一列的填上相同的数. 为什么?

因为一对 \(I\) 形的未标记格子只可能对应一个标记的格子, 而一对 \(L\) 形的可能对应两个标记的格子, 所以我们只需要保证这 \(4\) 个未标记格子分别组成的两组 \(L\) 形合法就够了.

所以我们就判断一下, 如果这个标记的格子周围只有两个未标记的, 直接连边, 四个的话, 把四个 \(L\) 连起来, 注意, 是双向边.

\(code:\)

#include
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
#define calc(i, j) (i - 1) * m + j
int read() {
int x = 0, f = 1;
char ch = getchar();
for (; !isdigit(ch); ch = getchar()) if (ch == '-') f = -1;
for (; isdigit(ch); ch = getchar()) x = (x <<1) + (x <<3) + (ch ^ 48);
return x * f;
}
const int N = 505, M = 1e6 + 5;
int n, m;
int a[N][N], ans[N * N];
int tot, to[M], nxt[M], head[M];
char s[N][N];
void Add(int u, int v) {
to[++tot] = v, nxt[tot] = head[u], head[u] = tot;
to[++tot] = u, nxt[tot] = head[v], head[v] = tot;
}
bool Check(int i, int j, int k, int l) {
if (!a[i][j] && !a[k][l]) return true;
return false;
}
int Sum(int x, int y) {
int sum = 0;
if (!a[x - 1][y]) sum += ans[calc(x - 1, y)];
if (!a[x][y - 1]) sum += ans[calc(x, y - 1)];
if (!a[x][y + 1]) sum += ans[calc(x, y + 1)];
if (!a[x + 1][y]) sum += ans[calc(x + 1, y)];
return sum;
}
void DFS(int x, int fa) {
ans[x] = 5 - ans[fa];
for (int i = head[x]; i; i = nxt[i]) {
int y = to[i];
if (!ans[y]) DFS(y, x);
}
}
int main() {
n = read(), m = read(), ans[0] = 1;
for (int i = 1; i <= n; i++) {
scanf("%s", s[i] + 1);
for (int j = 1; j <= m; j++) a[i][j] = s[i][j] == 'X';
}
for (int i = 2; i for (int j = 2; j if (a[i][j]) { //判断无解
if (a[i - 1][j] + a[i][j - 1] + a[i][j + 1] + a[i + 1][j] & 1) {
printf("NO");
return 0;
}
if (Check(i - 1, j, i + 1, j) && !Check(i, j - 1, i, j + 1)) Add(calc(i - 1, j), calc(i + 1, j));
else if (!Check(i - 1, j, i + 1, j) && Check(i, j - 1, i, j + 1)) Add(calc(i, j - 1), calc(i, j + 1));
else {
if (Check(i - 1, j, i, j + 1)) Add(calc(i - 1, j), calc(i, j + 1));
if (Check(i, j + 1, i + 1, j)) Add(calc(i, j + 1), calc(i + 1, j));
if (Check(i + 1, j, i, j - 1)) Add(calc(i + 1, j), calc(i, j - 1));
if (Check(i, j - 1, i - 1, j)) Add(calc(i, j - 1), calc(i - 1, j));
}
}
}
}
for (int i = 1; i <= n; i++) { //染色
for (int j = 1; j <= m; j++) {
if (!ans[calc(i, j)] && !a[i][j]) DFS(calc(i, j), 0);
}
}
for (int i = 1; i <= n; i++) { //统计 marked cell 的答案
for (int j = 1; j <= m; j++) {
if (a[i][j]) {
ans[calc(i, j)] = Sum(i, j);
}
}
}
printf("YES\n");
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m; j++) printf("%d ", ans[calc(i, j)]);
printf("\n");
}
return 0;
}

看不见我看不见我看不见我



推荐阅读
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 本文详细介绍了暂估入库的会计分录处理方法,包括账务处理的具体步骤和注意事项。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 郑州大学在211高校中的地位与排名解析
    本文将详细解读郑州大学作为一所位于河南省的211和双一流B类高校,在全国211高校中的地位与排名,帮助高三学生更好地了解这所知名学府的实力与发展前景。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 优化ASM字节码操作:简化类转换与移除冗余指令
    本文探讨如何利用ASM框架进行字节码操作,以优化现有类的转换过程,简化复杂的转换逻辑,并移除不必要的加0操作。通过这些技术手段,可以显著提升代码性能和可维护性。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 电子元件封装库:三极管、MOS管及部分LDO(含3D模型)
    本资源汇集了常用的插件和贴片三极管、MOS管以及部分LDO的封装,涵盖TO和SOT系列。所有封装均配有高质量的3D模型,共计96种,满足日常设计需求。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 小红书提高MCN机构入驻门槛,需缴纳20万元保证金
    近期,小红书对MCN机构的入驻要求进行了调整,明确要求MCN机构在入驻时需缴纳20万元人民币的保证金。此举旨在进一步规范平台内容生态,确保社区的真实性和用户体验。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 动物餐厅高效获取小鱼干攻略
    本文将介绍2023年动物餐厅中快速赚取小鱼干的有效方法,帮助玩家更轻松地积累资源。 ... [详细]
author-avatar
当王子爱上灰姑娘
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有