P3064 [USACO12DEC]伊斯坦布尔的帮派 (模拟)
题意:
一片草地,每次可以只可以让一种牛占领,问你怎样安排牛的次序
最后剩下的是1号牛,并且输出其数量
思路:
看到n到100 ,所以可以(n^3)暴力,第一重遍历次序,第二枚举是哪只牛
第三个for验证
然后在验证可否这里,我们的目标是让1号牛留到最后,所以我们要尽可能让
其他牛打架,并且数量多的牛影响最大,要最小消去
代码:
#include<bits/stdc++.h>
using namespace std;
#define N 105
int n,m;
int a[N],b[N];
int gang,cow; void fight(int &gang,int &cow,int j)//记录把j号牛加进来后场地上占领的牛的编号和牛的数量
{
if(cow==) gang=j;
if(gang==j) cow++;
else cow--;
}
int solve(int gang,int cow)//贪心地把数量多的牛去消去,看最后剩下的是不是1号牛
{
for(int i=;i<=m;i++) b[i]=a[i];
sort(b+,b+m+);
while(b[m])
{
for(int i=m;i>=;i--)
{
fight(gang,cow,i);
b[i]--;
if(b[i]>=b[i-]) break;
}
}
for(int i=;i<=b[];i++)
fight(gang,cow,);
if(gang==) return cow;
else return ;
}
int main()
{
while(~scanf("%d %d",&n,&m))
{
for(int i=;i<=m;i++) scanf("%d",&a[i]);
int num=solve(,);
if(num==)
{
puts("NO");
continue;
}
puts("YES");
printf("%d\n",num);
for(int i=;i<=n;i++)//枚举次数
{
int tmp_gang=gang;
int tmp_cow=cow;
for(int j=;j<=m;j++)//枚举每次用的是那只牛
{
if(!a[j]) continue;
a[j]--;
fight(gang,cow,j);
if(solve(gang,cow)==num)
{
printf("%d\n",j);
break;
}
a[j]++;
gang=tmp_gang;
cow=tmp_cow;
}
}
}
return ;
}
P3064 [USACO12DEC]伊斯坦布尔的帮派 (模拟)的更多相关文章
- [LuoguP3064][USACO12DEC]伊斯坦布尔的帮派Gangs of Istanbull(加强版)_线段树_贪心
伊斯坦布尔的帮派Gangs of Istanbull 题目链接:https://www.luogu.org/problem/P3064 数据范围:略. 题解: 这个题其实分为两问,第一问是$YES$. ...
- App开发:模拟服务器数据接口 - MockApi
为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...
- 故障重现, JAVA进程内存不够时突然挂掉模拟
背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...
- Python 爬虫模拟登陆知乎
在之前写过一篇使用python爬虫爬取电影天堂资源的博客,重点是如何解析页面和提高爬虫的效率.由于电影天堂上的资源获取权限是所有人都一样的,所以不需要进行登录验证操作,写完那篇文章后又花了些时间研究了 ...
- HTML 事件(四) 模拟事件操作
本篇主要介绍HTML DOM中事件的模拟操作. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4. ...
- 模拟AngularJS之依赖注入
一.概述 AngularJS有一经典之处就是依赖注入,对于什么是依赖注入,熟悉spring的同学应该都非常了解了,但,对于前端而言,还是比较新颖的. 依赖注入,简而言之,就是解除硬编码,达到解偶的目的 ...
- webapp应用--模拟电子书翻页效果
前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...
- javascript动画系列第一篇——模拟拖拽
× 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容 ...
- C++ 事件驱动型银行排队模拟
最近重拾之前半途而废的C++,恰好看到了<C++ 实现银行排队服务模拟>,但是没有实验楼的会员,看不到具体的实现,正好用来作为练习. 模拟的是银行的排队叫号系统,所有顾客以先来后到的顺序在 ...
随机推荐
- 匿名函数 python内置方法(max/min/filter/map/sorted/reduce)面向过程编程
目录 函数进阶三 1. 匿名函数 1. 什么是匿名函数 2. 匿名函数的语法 3. 能和匿名函数联用的一些方法 2. python解释器内置方法 3. 异常处理 面向过程编程 函数进阶三 1. 匿名函 ...
- man clock
CLOCK(3) Linux程序员手册 CLOCK(3) 名称 时钟-确定处理器时间 简介 #include <time.h> clock_t clock(void); ...
- 进行移动端rem适配
(function (designWidth, maxWidth) { var doc = document, win = window; var docEl = doc.documentElemen ...
- 利用Django框架实现分页 demo
- Android - Gradle架构中使用的“.so”库
Android使用Gradle架构的Android应用,需要对.so库做特殊的处理,因为会找不到,就会导致编译正确,使用错误:常见的使用情况是根据不同的cpu,有不同的库,包括:armeabi,mip ...
- Mysql中主键与索引
摘自: https://www.cnblogs.com/wicub/p/5898286.html 一.什么是索引?索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存.如果没 ...
- Python编程:从入门到实践—变量和简单数据类型
变量的命名和使用 #!/usr/bin/env python# -*- encoding:utf-8 -*- message ="Hello Python world!"print ...
- Java操作数据库之JDBC增删改查
1.java连接MySql数据库 代码区域: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 ...
- 2014 ECML: Covariate-correlated lasso for feature selection (ccLasso)
今天看了一篇 ECML 14 的文章(如题),记录一下. 原文链接:http://link.springer.com/chapter/10.1007/978-3-662-44848-9_38 这篇文章 ...
- java设置RabbitMQ的消费处理出现:ConditionalRejectingErrorHandler : Execution of Rabbit message listener failed.
WARN 7868 --- [cTaskExecutor-1] s.a.r.l.ConditionalRejectingErrorHandler : Execution of Rabbit messa ...