当前位置: 首页 > 编程日记 > 正文

BZOJ 1124: [POI2008]枪战Maf(构造 + 贪心)

题意

\(n\) 个人,每个人手里有一把手枪。一开始所有人都选定一个人瞄准(有可能瞄准自己)。然后他们按某个顺序开枪,且任意时刻只有一个人开枪。

因此,对于不同的开枪顺序,最后死的人也不同。

问最后死的人数最小值以及最大值。 \((1 \le n \le 10^6)\)

题解

不难发现是一道思博构造题。

首先考虑下最大值,我们只需要把这张图分三种情况讨论:

  1. 单个自环,贡献为 \(1\)
  2. 一个大于 \(1\) 的环,贡献为 \(len - 1\)
  3. 一个基环树,贡献为 \(size - num_{leaf}\)

对于最小值的话,我们可以不断模拟。

具体来说就是一开始把入度为 \(0\) 的人加入,这些人是活着的,然后他们瞄准的人就是必死的。

每次考虑连续三个点就行了,他们的顺序就是 活 \(\to\)\(\to\) 活 的。(其实第三个人不一定活的)

然后我们对于第三个点的入度就会 \(-1\) ,如果为 \(0\) 我们加进队列继续操作。(这就意味着,它在其中任何一次死了。我们都不会加进去)

然后这样不断操作,最后只会留下环,不难发现环上至少死 \(\displaystyle \lceil \frac{len}{2} \rceil\) 个人,这样就可以做完了qwq

总结

构造题认真想想还是想的出来的,但是需要大胆猜想小心求证才行qwq

代码

这道题实现起来其实有一些巧妙之处,建议读者仔细阅读。(参考了一下 ACist大佬的博客 )

我这个代码加上流输入,就可以取得 BZOJ 速度 rank1 的好成绩qwq

#include <bits/stdc++.h>#define For(i, l, r) for(register int i = (l), i##end = (int)(r); i <= i##end; ++i)
#define Fordown(i, r, l) for(register int i = (r), i##end = (int)(l); i >= i##end; --i)
#define Set(a, v) memset(a, v, sizeof(a))
#define Cpy(a, b) memcpy(a, b, sizeof(a))
#define debug(x) cout << #x << ": " << x << endl
#define DEBUG(...) fprintf(stderr, __VA_ARGS__)using namespace std;inline bool chkmin(int &a, int b) {return b < a ? a = b, 1 : 0;}
inline bool chkmax(int &a, int b) {return b > a ? a = b, 1 : 0;}namespace pb_ds
{   namespace io{const int MaxBuff = 1 << 16;const int Output = 1 << 22;char B[MaxBuff], *S = B, *T = B;#define getc() ((S == T) && (T = (S = B) + fread(B, 1, MaxBuff, stdin), S == T) ? 0 : *S++)char Out[Output], *iter = Out;inline void flush(){fwrite(Out, 1, iter - Out, stdout);iter = Out;}}template<class Type> inline Type read(){using namespace io;register char ch; register Type ans = 0; register bool neg = 0;while(ch = getc(), (ch < '0' || ch > '9') && ch != '-')     ;ch == '-' ? neg = 1 : ans = ch - '0';while(ch = getc(), '0' <= ch && ch <= '9') ans = ans * 10 + ch - '0';return neg ? -ans : ans;}
}using namespace pb_ds;void File() {
#ifdef zjp_shadowfreopen ("1124.in", "r", stdin);freopen ("1124.out", "w", stdout);
#endif
}const int N = 1e6 + 1e3;int n, aim[N], deg[N], maxlive, minlive; bitset<N> dead, arrive;int main () {File();n = read<int>();For (i, 1, n) ++ deg[aim[i] = read<int>()];queue<int> Q;For (i, 1, n) if (!deg[i]) Q.push(i), ++ minlive;while (!Q.empty()) {int u = aim[Q.front()], v = aim[u]; Q.pop();++ maxlive; if (dead[u]) continue ;dead[u] = true; arrive[v] = true;if (!(-- deg[v])) Q.push(v);}For (i, 1, n) if (deg[i] && !dead[i]) {int len = 0; bool flag = false;for (register int u = i; !dead[u]; u = aim[u]) dead[u] = true, ++ len, flag |= arrive[u];if (!flag && len > 1) ++ minlive;maxlive += len / 2;}printf ("%d %d\n", n - maxlive, n - minlive);return 0;
}

转载于:https://www.cnblogs.com/zjp-shadow/p/9477479.html

相关文章:

Maven跳过测试

Maven跳过测试用例 在properties中声明<properties><maven.test.skip>true</maven.test.skip> </properties> 或者 <properties><skipTests>true</skipTests> </properties> 在执行命令中声明mvn test -Dmaven.test.skiptrue …

Linux内核 题目,《Linux内核完全注释》部分习题答案

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼第3章 内核引导和启动过程2.为什么不直接将system模块搬到0x00000处而是先搬到0x10000处&#xff0c;再搬到0x00000处呢&#xff1f;在机器开机上电时&#xff0c;ROM BIOS将bootsect代码加载到内存的固定位置0x7c00处&#xff0c;…

java jdk 1.8 安装_下载、安装、配置 java jdk1.8

近期配置react native的开发环境&#xff0c;所以就从配置环境开始。rn的环境配置有那么几项&#xff0c;其中重要的一个就是java jdk(Java Development Kit 的缩写)&#xff0c;那么以下就是下载、安装还有配置的流程1.下载java jdk 1.8在地址栏输入 java jdk,如下图所示&…

liunx php redis扩展,CentOS 7下安装php-redis扩展及简单使用

前言&#xff1a;在本篇文章中&#xff0c;我将给大家介绍如何在CentOS7上安装PHP-Redis扩展以及一些简单的实用&#xff0c;关于如何在Centos上安装redis的&#xff0c;可以参考想要在php中操作redis&#xff0c;那就必须安装php-redis扩展&#xff0c;就比如MySQL一样&#x…

Luogu 2470 [SCOI2007]压缩

和Luogu 4302 [SCOI2003]字符串折叠 差不多的想法&#xff0c;区间dp 为了计算方便&#xff0c;我们可以假设区间[l, r]的前面放了一个M&#xff0c;设$f_{i, j, 0/1}$表示区间$[i, j]$中是否存在M 因为这题只能是二的幂次倍压缩&#xff0c;所以转移的时候枚举中点chk是否合法…

做图形处理Linux小型主机,8个优秀的linux图形图像工具

对艺术家、摄影师、动画师和设计师而言&#xff0c;Linux是一个有潜力的平台。廉价的硬件&#xff0c;优秀的免费软件&#xff0c;任何有才华的人都能在上面创作专业水平的计算机图形。开源社区提供了丰富的开源图形工具&#xff0c;但要慧眼识珠并非易事。这里介绍的优秀图形工…

使用laravel框架的eloquent\DB模型连接多个数据库

1、配置.env文件 DB_HOST_TRAILER127.0.0.1DB_PORT_TRAILER3306DB_DATABASE_TRAILERhtms_trailerDB_USERNAME_TRAILERrootDB_PASSWORD_TRAILER DB_HOST_FREIGHT127.0.0.1DB_PORT_FREIGHT3306DB_DATABASE_FREIGHThangli_saasDB_USERNAME_FREIGHTrootDB_PASSWORD_FREIGHT 2、配置…

java openfile busy_android java.io.IOException: open failed: EBUSY (Device or resource busy)

今天遇到一个奇怪的问题&#xff0c;测试在程序的下载界面&#xff0c;下载一个文件第一次下载成功&#xff0c;删除后再下载结果下载报错&#xff0c;程序&#xff1a;file.createNewFile();报错&#xff1a;java.io.IOException: open failed: EBUSY (Device or resource bus…

java service注入失败,使用spring向service里面注入dao不成功。

使用spring向service里面注入dao不成功。求救啊&#xff01;本帖最后由 PaperStar 于 2013-12-26 19:29:20 编辑页面调用action&#xff0c;action调用service&#xff0c;service调用dao用Debug查看action调用service方法时service有值&#xff0c;但是service调用dao时&#…

下面为初学者分享一下SQL 数据库学习资料

一、基础1、说明&#xff1a;创建数据库CREATE DATABASE database-name2、说明&#xff1a;删除数据库drop database dbname3、说明&#xff1a;备份sql server--- 创建 备份数据的 deviceUSE masterEXEC sp_addumpdevice disk, testBack, c:\mssql7backup\MyNwind_1.dat--- 开…

linux7设置时间,CentOS 7 设置日期和时间

现代操作系统分为以下两种类型的时钟&#xff1a;实时时钟(Real-Time Clock&#xff0c;RTC)&#xff0c;通常称为硬件时钟(一般是系统主板上的集成电路)&#xff0c;它完全独立于操作系统的当前状态&#xff0c;即使在计算机关闭时也能运行。系统时钟&#xff0c;也称为软件时…

SQLMap安装步骤

SQLMap是利用Python语言写的&#xff0c;所以需要将Python这个语言环境给安装上 &#xff1a; 1、首先下载Python(这里Python版本为2.7.2&#xff0c;可以下载不同或高版本的) 2、然后在下载sqlmap&#xff08;http://sqlmap.org&#xff09; 3、这两个软件下载完成后&#xff…

am5718_AM5718如何扩大内存 - Sitara™ Cortex-A8 和 ARM9 微处理器 - Sitara™ Cortex-A8 和 ARM9 微处理器 - E2E™ 中文支持论坛...

谢谢了Shine,你的资料和建议非常到位&#xff0c;按您的建议&#xff0c;修改了board.c以下两处&#xff0c;问题解决了。1&#xff1a;board/ti/am57xx/board.c文件static const struct dmm_lisa_map_regs am571x_idk_lisa_regs {.dmm_lisa_map_3 0x80640100,.is_ma_present…

亚马逊刊登php代码,最全的亚马逊刊登listing工具了解一下

如果你是亚马逊FBA卖家&#xff0c;那么你可能会错过很多有用的亚马逊listing工具。这些listing工具可以批量上传listing&#xff0c;同时还可以记录产品特征&#xff0c;以及打印运输标签。1、易仓刊登系统易仓刊登系统是一款易仓基于已有ERP客户需求研发的一套平台产品刊登系…

linux重命名tar命令,linux常用操作指令4 —— 文件操作相关命令(mkdir、touch、rm、mv、cp、cat 、 find 、tar、chmod)...

文件操作相关命令文件操作相关命令1、创建文件夹mkdir2、创建文件touch3、移动文件夹mv(类似于剪切)4、删除rm5、重命名mv6、复制cp7、查看文件(cat、head、tail..)8、查找文件 find (重要)9、归档压缩tar10、修改文件权限chmod参考文件操作相关命令1、创建文件夹mkdir# mkdir …

后台生成小程序码

工作需要&#xff0c;根据动态参数生成小程序二维码。 找了下开发API &#xff1a;https://developers.weixin.qq.com/miniprogram/dev/api/qrcode.html 选择了B接口&#xff0c;可以无限生成&#xff0c;只是参数有点限制&#xff0c;但是可以满足需求&#xff0c;开搞。 一、…

2017-02-20 注册.Net Framework4.0

在使用IIS发布Web应用程序时&#xff0c;有时会遇到Asp.Net 4.0尚未在Web服务器上注册的问题&#xff0c;需要手动注册下.Net Framework 4.0。 注册.net Framwork4.0 步骤&#xff0c;以windows7系统为例&#xff0c;注册 步骤如下&#xff1a; 64位操作系统&#xff1a; 1. …

java字符存储,在什么编码是Java字符存储在?

Is the Java char type guaranteed to be stored in any particular encoding?Edit: I phrased this question incorrectly. What I meant to ask is are char literals guaranteed to use any particular encoding?解决方案"Stored" where? All Strings in Java …

matlab 仿真步长,MATLAB Simulink变步长仿真与固定步长仿真简单对比

今天晚上翻了一下资料发现&#xff0c;关于变步长以及固定步长仿真的理解我之前是由错误理解的。当时没有做什么认真的思考活着尝试就自己给自己下了一个结论&#xff1a;变步长仿真会比较精确&#xff0c;但是可能会消耗更多的计算机资源&#xff01;错&#xff01;大错特错&a…

JS设计模式(13)状态模式

什么是状态模式&#xff1f; 定义&#xff1a;将事物内部的每个状态分别封装成类&#xff0c;内部状态改变会产生不同行为。 主要解决&#xff1a;对象的行为依赖于它的状态&#xff08;属性&#xff09;&#xff0c;并且可以根据它的状态改变而改变它的相关行为。 何时使用&am…

【转】Mac 程序员的十种武器

http://chijianqiang.baijia.baidu.com/article/3733 上 在写 Mac 程序员的十个武器之前&#xff0c;我决定先讲一个故事&#xff0c;关于 Mac 和爱情的。&#xff08;你们不是问 Mac 和爱情有个鸟关系吗&#xff1f;&#xff09; 从前有一个孩子叫做小明&#xff0c;他不是高帅…

git ignore linux,为什么说.gitignore不能忽视

我注意到很多开发者没有使用 .gitignore 文件&#xff0c;尽管使用 .gitignore 文件来指定你不希望 Git 在版本控制中跟踪的文件是最佳实践之一。.gitignore 可以提高代码质量&#xff0c;所以你不应该忽略版本库中的 .gitignore。什么是 .gitignore?Git 仓库中的文件可以是&a…

java arcengine_在Java程序中调用ArcEngine

ArcEngine一般在C#中用的比较多&#xff0c;不过esri也是为Java提供了AE的类库的&#xff0c;不过文档确实没做的C#那么好。下面我记录一下如何在项目中配置使用AE的环境。第一步&#xff1a;将arcobject.jar包加到build path下&#xff1b;第二步&#xff1a;要使用AE&#xf…

matlab 实例均命名为,MATLAB复习题

第一章MATLAB 概述1、标点符号( &#xff1b; )可使命令行不显示运算结果&#xff0c;( % )用来表示该行是注释行。(常用标点符号的功能见P9)2、用“format”命令设置数据输出形式&#xff0c;(format long )将pi 显示为3.14159265358979&#xff0c;(format short e )将pi 显示…

爬虫之Scrapy

Scrapy初步 Scrapy基于Twisted设计实现&#xff0c;Twisted的特殊特性是以事件驱动&#xff0c;并且对于异步的支持性很好&#xff0c;集成了高性能的异步下载&#xff0c;队列&#xff0c;分布式&#xff0c;持久化等。 Scrapy的安装 在Linux中可以直接在命令行中输入&#xf…

java 8 lambda reduce_JDK8新特性Lambda表达式体验

“Lambda 表达式”(lambda expression)是一个匿名函数&#xff0c;Lambda表达式基于数学中的λ演算得名&#xff0c;直接对应于其中的lambda抽象(lambda abstraction)&#xff0c;是一个匿名函数&#xff0c;即没有函数名的函数。Java 8的一个大亮点是引入Lambda表达式&#xf…

php display_errors

// 检测开发环境public function setReporting(){if (APP_DEBUG true) {error_reporting(E_ALL);ini_set(display_errors,On);} else {error_reporting(E_ALL);ini_set(display_errors,Off);ini_set(log_errors, On);ini_set(error_log, RUNTIME_PATH. logs/error.log);}} 在p…

linux esd转iso,window_Win10 TH2正式版10586官方ESD映像怎么转换成ISO镜像?,今天phpstudy分享了Win10 TH2(Build - phpStudy...

Win10 TH2正式版10586官方ESD映像怎么转换成ISO镜像?今天phpstudy分享了Win10 TH2(Build 10586)各版本官方ESD映像下载地址&#xff0c;不过旧转换工具可能已不适用于新版ESD映像&#xff0c;特别是新版本增加了专业版和家庭版二合一映像&#xff0c;而以往都是单版本。本文使…

mysql在线上建索引,mysql 5.6在线DDL建索引测试

基本信息&#xff1a;mysql版本&#xff1a;(product)rootlocalhost [(none)]> select version;------------| version |------------| 5.6.29-log |------------1 row in set (0.00 sec)表payment的记录数:(product)rootlocalhost [sakila]> select count(*) from paym…

接口测试(postman jmeter)

接口&#xff1a;把client&#xff08;前端&#xff09;和server&#xff08;后端&#xff09;联系起来的就是接口&#xff0c;接口测试就是功能测试&#xff0c;进行接口测试首先得需要接口文档。 json是一种通用的数据格式&#xff0c;接口返回的数据都是json&#xff0c;jso…