CF1465-C. Peaceful Rooks

预备小知识:

Rook(国际象棋中的车)。

国际象棋中的棋子。每人有2个,他只能直走,不能斜走,除王车易位外不能越子。

—— 来自《百度百科》


题意:

题目给出一个\(n\times n\)的棋盘,棋盘中有\(m(m<n)\)个车。最一开始任意两个车都不能打到对方(即都不在同一行或同一列)。

每一个回合你可以让一个车水平或垂直移动任意距离,但是要求车移动后不能让其他车可以打到它。现在问你至少多少回合之后,所有车能够都移动到主对角线上。


思路:

正常情况下每个车直接移动到它对应的主对角线上肯定是最优解。

但是大部分情况下车要移动到它对应的主对角线上的时候会发现那个位置要么所在行有车,要么所在列有车,那么所在行或列上的那个棋子就要先移动到那个棋子对应的主对角线上,但是又发现那个棋子对应主对角线上的位置的行或列有车,那么就要... ...这种最终会有两种情况发生:

一种是最终的棋子对应的主对角线位置所在行或列上都没有棋子,那么这时候它以及它之前的所有棋子都可以一步到达主对角线上;

另一种是最终的棋子对应的主对角线位置所在行或列上有棋子,并且这个棋子是第一个棋子,即形成了这样的环:\(a->b->c->d->a\),那么这时候只要也只有破坏这个环之后,才能把每个棋子移动到主对角线位置。破坏的方法其实很简单,只要把环中的某一个棋子移动到一个所在行所在列没有其他棋子的位置就可以破坏这个环,等其他棋子都移动到主对角线上再把这个棋子移动到它对应的主对角线上即可。这样第二种情况移动的总次数就是环中所有棋子的个数加一(破坏环的时候多移动了一步)。

判断环就用并查集就可以(本蒟蒻一开始还用dfs。。),每个车\((x, y)\)相当于一个边连接了点\(x\)和点\(y\),答案就是不在对角线上车的数量加上环的数量。


AC代码:

#include <cstdio>
#include <cstring>
#include <iostream> const int maxn = 100005; int father[maxn]; int Find(int x) {
return father[x] == x ? x : father[x] = Find (father[x]);
} void Union(int u, int v) {
if (Find(u) != Find(v)) {
father[Find(u)] = Find(v);
}
} int main() {
int T, n, m;
scanf("%d", &T);
while (T--) {
scanf("%d %d", &n, &m);
for (int i = 0; i <= n; i++) {
father[i] = i;
}
int u, v;
int ans = 0;
for (int i = 0; i < m; i++) {
scanf("%d %d", &u, &v);
if (u == v) {
continue;
} else if (Find(u) == Find(v)) {
ans += 2;
} else {
ans += 1;
Union(u, v);
}
}
printf("%d\n", ans);
} return 0;
}

CF1465-C. Peaceful Rooks的更多相关文章

  1. Codeforces Round #692 (Div. 2, based on Technocup 2021 Elimination Round 3) C. Peaceful Rooks (思维,dsu找环)

    题意:一个棋盘上有一些"车",现在要让这些"车"跑到左倾斜的对角线上,每次可以移动一个棋子,但是棋盘的任意时刻都不能出现一个"车"能吃另一个 ...

  2. Codeforces Round #692 (Div. 2, based on Technocup 2021 Elimination Round 3)

    A.In-game Chat 题目:就是从后面数连着的'('的个数是不是严格比剩下的字符多 思路:水题,直接从后往前遍历即可 代码: #include<iostream> #include ...

  3. UVA - 11134 Fabled Rooks[贪心 问题分解]

    UVA - 11134 Fabled Rooks We would like to place n rooks, 1 ≤ n ≤ 5000, on a n × n board subject to t ...

  4. (light OJ 1005) Rooks dp

    http://www.lightoj.com/volume_showproblem.php?problem=1005        PDF (English) Statistics Forum Tim ...

  5. 01_传说中的车(Fabled Rooks UVa 11134 贪心问题)

    问题来源:刘汝佳<算法竞赛入门经典--训练指南> P81: 问题描述:你的任务是在n*n(1<=n<=5000)的棋盘上放n辆车,使得任意两辆车不相互攻击,且第i辆车在一个给定 ...

  6. uva 11134 fabled rooks (贪心)——yhx

    We would like to place n rooks, 1 n 5000, on a n nboard subject to the following restrictions• The i ...

  7. L - Fabled Rooks(中途相遇法和贪心)

    Problem F: Fabled Rooks We would like to place n rooks, 1 ≤ n ≤ 5000, on a n×n board subject to the ...

  8. UVA 11134 - Fabled Rooks(贪心+优先队列)

    We would like to place  n  rooks, 1 ≤  n  ≤ 5000, on a  n×n  board subject to the following restrict ...

  9. 贪心 uvaoj 11134 Fabled Rooks

    Problem F: Fabled Rooks We would like to place n rooks, 1 ≤ n ≤ 5000, on a n×n board subject to the ...

随机推荐

  1. --safe-user-create

    此参数如果启用,用户将不能用grant语句创建新用户,除非用户有mysql数据库中user表的insert权限, ./mysqld_safe  --safe-user-create & 用-- ...

  2. mysqldump 的-T参数

    /usr/local/mysql/bin/mysqldump -uroot -T /tmp lina xuehao 把lina数据库中的xuehao表在tmp目录下备份出来两个文件,一个是纯数据.tx ...

  3. LRU(Least Recently Used)最近未使用置换算法--c实现

    在OS中,一些程序的大小超过内存的大小(比如好几十G的游戏要在16G的内存上跑),便产生了虚拟内存的概念 我们通过给每个进程适当的物理块(内存),只让经常被调用的页面常驻在物理块上,不常用的页面就放在 ...

  4. Promise.all()使用实例

    一.什么是Promise.all()? 在说这个之前要先说清楚promise.promise就是一个对象,专门用来处理异步操作的. 而Promise.all方法用于将多个 Promise 实例,包装成 ...

  5. SQLSERVER 修改数据实例的排序规则

    SQL Server服务器修改排序规则的方法 操作及验证步骤: 1 登录数据库后,查看当前安装数据库默认排序规则的两种方式 方式一.使用SQL Server 2014 Management Studi ...

  6. 使用 gitlab-runner 持续集成

    gitlab-runner 是 Gitlab 推出的与 Gitlab CI 配合使用的持续集成工具.当开发人员在 Gitlab 上更新代码之后,Gitlab CI 服务能够检测到代码更新,此时可以触发 ...

  7. 订阅者模式,公众号、B站、快手用了都说好!

    大家好,今天和大家来聊一个新的设计模式--订阅者模式. 这个模式在我们的生活当中非常常见,可以说是几乎所有的媒体平台都用或多或少地用到了这个模式.比如公众号,我们来仔细梳理一下公众号这个平台当中的整个 ...

  8. 小白也能看懂的ACID与隔离级别

    前言 现如今JAVA开发工程师的数量越来越多,但大多数工程师平时做的工作都是简单的CRUD,当你一直处于这种舒适的环境中不追求进步的时候,如果哪一天你突然想要改变环境,换个工作,去与面试官当面聊技术的 ...

  9. 针对Fluent-Bit采集容器日志的补充

    hello,之前我写过<一套标准的ASP.NET Core容器化应用日志收集分析方案>,在公司团队.微信公众号.Github上反映良好. 其中配置Fluent-bit使用Forward协议 ...

  10. nodejs的调试debug

    目录 简介 开启nodejs的调试 调试的安全性 使用WebStorm进行nodejs调试 使用Chrome devTools进行调试 使用node-inspect来进行调试 其他的debug客户端 ...