热门标签 | 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;
}

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



推荐阅读
  • 使用Numpy实现无外部库依赖的双线性插值图像缩放
    本文介绍如何仅使用Numpy库,通过双线性插值方法实现图像的高效缩放,避免了对OpenCV等图像处理库的依赖。文中详细解释了算法原理,并提供了完整的代码示例。 ... [详细]
  • 深入理解父组件与子组件的引用和访问
    本文详细介绍了如何在Vue.js中通过$children和$refs属性实现父组件对子组件的访问,并提供了具体的代码示例及最佳实践。 ... [详细]
  • 极大似然估计(MLE)及其3D可视化解析
    本文详细介绍了极大似然估计(Maximum Likelihood Estimation, MLE)的推导过程,并通过3D可视化展示其在概率密度函数中的应用。我们将探讨如何利用MLE来估计参数,以及它在实际问题中的重要性。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 本文介绍如何解决在 IIS 环境下 PHP 页面无法找到的问题。主要步骤包括配置 Internet 信息服务管理器中的 ISAPI 扩展和 Active Server Pages 设置,确保 PHP 脚本能够正常运行。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 探讨一个老旧 PHP MySQL 系统中,时间戳字段不定期出现异常值的问题及其可能原因。 ... [详细]
  • 国内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学院始终是我信赖的学习平台。 ... [详细]
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社区 版权所有