博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[APIO2007]动物园
阅读量:4665 次
发布时间:2019-06-09

本文共 2444 字,大约阅读时间需要 8 分钟。

新建的圆形动物园是亚太地区的骄傲。圆形动物园坐落于太平洋的一个小岛上,包含一大圈围栏,每个围栏里有一种动物。如下图所示:

你是动物园的公共主管。你要做的是,让每个来动物园的人都尽可能高兴。今天有一群小朋友来动物园参观,你希望能让他们在动物园度过一段美好的时光。但这并不是一件容易的事——有的动物有一些小朋友喜欢,有的动物有一些小朋友害怕。如,Alex 喜欢可爱的猴子和考拉,而害怕拥牙齿锋利的狮子。而Polly 会因狮子有美丽的鬃毛而喜欢它,但害怕有臭味的考拉。

你可以选择将一些动物从围栏中移走以使得小朋友不会害怕。但你不能移走所有的动物,否则小朋友们就没有动物可看了。

每个小朋友站在大围栏圈的外面,可以看到连续的 5 个围栏。你得到了所有小朋友喜欢和害怕的动物信息。当下面两处情况之一发生时,小朋友就会高兴:

  • 至少有一个他害怕的动物被移走

  • 至少有一个他喜欢的动物没被移走

例如,考虑下图中的小朋友和动物:

假如你将围栏 4 和 12 的动物移走。Alex 和 Ka-Shu 将很高兴,因为至少有一个他们害怕的动物被移走了。这也会使 Chaitanya 高兴,因为他喜欢的围栏 6 和8 中的动物都保留了。但是,Polly 和 Hwan 将不高兴,因为他们看不到任何他们喜欢的动物,而他们害怕的动物都还在。这种安排方式使得三个小朋友高兴。

现在,换一种方法,如果你将围栏 4 和 6 中的动物移走,Alex 和 Polly 将很高兴,因为他们害怕的动物被移走了。Chaitanya 也会高兴,虽然他喜欢的动物 6被移走了,他仍可以看到围栏 8 里面他喜欢的动物。同样的 Hwan 也会因可以看到自己喜欢的动物 12 而高兴。唯一不高兴的只有 Ka-Shu。

如果你只移走围栏 13 中的动物,Ka-Shu 将高兴,因为有一个他害怕的动物被移走了,Alex, Polly, Chaitanya 和 Hwan 也会高兴,因为他们都可以看到至少一个他们喜欢的动物。所以有 5 个小朋友会高兴。这种方法使得了最多的小朋友高兴。

输入格式

输入的第一行包含两个整数 N,C,用空格分隔。N 是围栏数(1≤N≤10 000),C是小朋友的个数(1≤C≤50 000)。围栏按照顺时针的方向编号为 1,2,3,…,N。

接下来的 C 行,每行描述一个小朋友,描述下面的形式给出:

E F L X1 X2 … XF Y1 Y2 … YL

其中:

E 表示小朋友可以看到的第一个围栏的编号(1≤E≤N),也就是说,小朋友可以看到的围栏为 E,E+1,E+2,E+3,E+4。注意,如果编号超过 N 将继续从 1 开始算。

如:当 N=14,E=13 时,小朋友可以看到的围栏为 13,14,1,2 和 3。 F 表示小朋友害怕的动物数。L 表示小朋友喜欢的动物数。

围栏 X1, X2, …, XF中包含小朋友害怕的动物。 围栏 Y1, Y2, …, YL中包含小朋友喜欢的动物。 X1, X2, …, XF, Y1, Y2, …, YL是两两不同的数,而且所表示的围栏都是小朋友可以看到的。

小朋友已经按照他们可以看到的第一个围栏的编号从小到大的顺序排好了(这样最小的E对应的小朋友排在第一个,最大的E对应的小朋友排在最后一个)。

注意可能有多于一个小朋友对应的 E 是相同的。


 

这题样例2是错的,纽曼表……

卡了我整整半个小时

#include
#define re return#define inc(i,l,r) for(int i=l;i<=r;++i)using namespace std;template
inline void rd(T&x){ char c;bool f=0; while((c=getchar())<'0'||c>'9')if(c=='-')f=1; x=c^48; while((c=getchar())>='0'&&c<='9')x=x*10+(c^48); if(f)x=-x;}int n,m;int f[50005][40],happy[50005][40]; //从当前位开始,往后5位的状态 main(){ freopen("in.txt","r",stdin); rd(n);rd(m); int F,L,E,x,like,fear; inc(i,1,m) { like=0;fear=0; rd(E);rd(F);rd(L); //将他喜欢与害怕的状态压缩 inc(j,1,F) { rd(x); like+=1<<((E+4-x)%n); } inc(j,1,L) { rd(x); fear+=1<<((E+4-x)%n); } //如果当前状态使他满意, inc(j,0,31) happy[E][j]+=((like&j)>0)|((fear&j)
>1],f[j-1][(k>>1)+16])+happy[j][k]; ans=max(ans,f[n][i]); //强制选回与开始时相同的状态 } printf("%d",ans); re 0;}

 

 

转载于:https://www.cnblogs.com/lsyyy/p/11394460.html

你可能感兴趣的文章
C语言-02基本运算
查看>>
轻巧快速的JSON工具--fastJSON
查看>>
生男生女预测软件,千人验证无误
查看>>
js call()和apply()方法的区别和用法详解
查看>>
Android之Service
查看>>
HDU 2795 Billboard 解题报告
查看>>
多线程——newCachedThreadPool线程池
查看>>
日志传输与清除脚本
查看>>
maven小知识点
查看>>
flash bulider 生成app无法安装在xcode模拟器上
查看>>
路由器中的PPP配置与DHCP服务器配置
查看>>
hdu3436 splaytree树模拟队列+离散化缩点
查看>>
2016弱校联盟十一专场10.2---Around the World(深搜+组合数、逆元)
查看>>
Windows下用C语言获取进程cpu使用率,内存使用,IO情况
查看>>
nandflash擦除、写操作的状态判断
查看>>
iOS照片缩略图thumbnail模糊问题
查看>>
有关使用百度编辑器Ueditor的问题
查看>>
定位决定人生成败
查看>>
ORACLE 创建新表
查看>>
在C#中获取IronPthon2.7异常时的调用方法堆栈,调试使用。
查看>>