题目链接:

https://codeforces.com/gym/102082

题意:

在一个客车里面有$r$排座位,每排座位有$2s$个座位,中间一条走廊

有$p$个人在车内,求出所有人走出客车的最短时间

数据范围:

$1\leq r\leq 500$

$1\leq s\leq 500$

$1\leq p\leq 2sp$

分析:

一道全场题,居然想了三个小时,我也是醉了。

解法一:模拟每秒他们的动作。如果有多个人下一秒要走向同一个位置,他们任何一个人走上去都行。重点是,这样的复杂度是$O(s^2n^2)$,但是可以发现在1000秒以后,他们所有的人一定紧贴着。所以以后每秒走出一个人,也就是说,可以停止模拟,直接得到答案(这是我比赛的时候想到的)

解法二:逆处理(orz),想让他们都出去,然后一个一个的放进去。所有的阻挡都在入口了。算出每个人就位的最长时间

解法三:算出每个人出来的时间(无人阻挡),然后每秒出去一个人,如果同一秒有多人,那么任意一个人出去,其它的人加在下一秒

ac代码:

解法一:

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=500+10;
const int maxm=1e7+10;
const int mod=1e9+7;
int r,s,p,ans;
int ma[maxn][2*maxn]; void mov()
{
if(ma[r][s+1])ma[r][s+1]=0,p--;
for(int i=r;i>=1;i--)
{
if(ma[i][s+1]&&ma[i+1][s+1]==0)ma[i+1][s+1]=1,ma[i][s+1]=0;
for(int j=s;j>=1;j--)
if(ma[i][j+1]==0&&ma[i][j])ma[i][j]=0,ma[i][j+1]=1;
for(int j=s+2;j<=2*s+1;j++)
if(ma[i][j-1]==0&&ma[i][j])ma[i][j-1]=1,ma[i][j]=0;
}
}
int main()
{
scanf("%d %d %d",&r,&s,&p);
for(int i=1;i<=p;i++)
{
int x,y;
scanf("%d %d",&x,&y);
if(y>s)y++;
ma[x][y]=1;
}
while(p)
{
ans++;
mov();
if(ans>=1000)break;
}
printf("%d\n",ans+p);
return 0;
}

解法二:

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=500+10;
const int maxm=1e7+10;
const int mod=1e9+7;
int r,s,p,ans;
int num[maxn*maxn*2];
int main()
{
scanf("%d %d %d",&r,&s,&p);
for(int i=1;i<=p;i++)
{
int x,y;
scanf("%d %d",&x,&y);
if(y>s)y++;
num[i]=abs(s+1-y)+abs(r+1-x);
//cout<<num[i]<<endl;
}
sort(num+1,num+1+p);
int ans=0;
for(int i=p;i>=1;i--)
ans=max(p-i+num[i],ans);
cout<<ans<<endl;
return 0;
}

解法三:

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=500+10;
const int maxm=1e7+10;
const int mod=1e9+7;
int r,s,p,ans;
int num[maxn*maxn*2];
int main()
{
scanf("%d %d %d",&r,&s,&p);
for(int i=1;i<=p;i++)
{
int x,y;
scanf("%d %d",&x,&y);
if(y>s)y++;
num[abs(s+1-y)+abs(r+1-x)]++;
//cout<<num[i]<<endl;
}
// sort(num+1,num+1+p);
int ans=0;
for(int i=1;i<maxn*maxn*2;i++)
{
if(num[i])
ans=max(i,ans);
if(num[i]>=2)num[i+1]+=num[i]-1;
}
cout<<ans<<endl;
return 0;
}

  

codeforces gym #102082C Emergency Evacuation(贪心Orz)的更多相关文章

  1. Codeforces Gym 100002 E "Evacuation Plan" 费用流

    "Evacuation Plan" Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/10 ...

  2. Codeforces Gym 100269E Energy Tycoon 贪心

    题目链接:http://codeforces.com/gym/100269/attachments 题意: 有长度为n个格子,你有两种操作,1是放一个长度为1的东西上去,2是放一个长度为2的东西上去 ...

  3. codeforces Gym 100338E Numbers (贪心,实现)

    题目:http://codeforces.com/gym/100338/attachments 贪心,每次枚举10的i次幂,除k后取余数r在用k-r补在10的幂上作为候选答案. #include< ...

  4. Codeforces Gym 100203E E - bits-Equalizer 贪心

    E - bits-EqualizerTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest ...

  5. CodeForces Gym 100685I Innovative Business (贪心)

    题意:给定一条路的长和宽,然后给你瓷砖的长和宽,你只能横着或者竖着铺,也可以切成片,但是每条边只能对应一条边,问你最少要多少瓷砖. 析:先整块整块的放,然后再考虑剩下部分,剩下的再分成3部分,先横着, ...

  6. ICPC 2018 亚洲横滨赛 C Emergency Evacuation(暴力,贪心)

    ICPC 2018 亚洲横滨赛 C Emergency Evacuation 题目大意 你一个车厢和一些人,这些人都坐在座位上,求这些人全部出去的时间最小值 Solution 题目咋说就咋做 直接模拟 ...

  7. Codeforces GYM 100876 J - Buying roads 题解

    Codeforces GYM 100876 J - Buying roads 题解 才不是因为有了图床来测试一下呢,哼( 题意 给你\(N\)个点,\(M\)条带权边的无向图,选出\(K\)条边,使得 ...

  8. Codeforces Gym 101252D&&floyd判圈算法学习笔记

    一句话题意:x0=1,xi+1=(Axi+xi%B)%C,如果x序列中存在最早的两个相同的元素,输出第二次出现的位置,若在2e7内无解则输出-1. 题解:都不到100天就AFO了才来学这floyd判圈 ...

  9. Codeforces Gym 101190M Mole Tunnels - 费用流

    题目传送门 传送门 题目大意 $m$只鼹鼠有$n$个巢穴,$n - 1$条长度为$1$的通道将它们连通且第$i(i > 1)$个巢穴与第$\left\lfloor \frac{i}{2}\rig ...

随机推荐

  1. webpack4.0各个击破(9)—— karma篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  2. springboot、springsecurity、jwt权限验证

    1.背景 基于前后端分离项目的后端模块: 2.相关技术 springboot全家桶 web模块 security模块:用于权限的验证 mongodb 模块:集成mogodb模块 jwt 用于token ...

  3. MySQL查询执行的基础——查询优化处理

    查询的生命周期的下一步是将一个SQL转换成一个可执行计划,MySQL再按照这个计划和存储引擎进行交互 语法解析器和预处理 首先,MySQL通过关键词将SQL语句进行解析,并生成一颗对应的"解 ...

  4. nodejs 搭建简易服务器

    www文件夹下 template文件夹下 server.js代码: const express=require('express'); const static=require('express-st ...

  5. sql server去掉某个字段前后空格问题

    数据通过页面表单保存到数据库,由于有个选项是一个树形的下拉框,导致保存的这个字段的数据前面有空格,在sql server中可以使用 SELECT LTRIM(RTRIM(BelongPartyCode ...

  6. 第五课 Css3旋转放大属性,正六边形的绘制

    ---恢复内容开始--- 一.效果 二.知识点 1.background-color: rgba(0,0,0,.4);   (红色.绿色.蓝色.透明度(0-1)) 2.position: absolu ...

  7. #WEB安全基础 : HTML/CSS | 0x10实现交互_表单

    先看看表单如何工作吧 请求   响应   简要工作流程: 浏览器加载页面 用户输入数据 用户提交表单 服务器响应 概念都清楚了,我们来写表单吧 只有一个html文件   这是显示   你可以向空白框框 ...

  8. 从.Net到Java学习第三篇——spring boot+mybatis+mysql

    从.Net到Java学习第一篇——开篇 环境:mysql5.7 新建mysql数据库demo,然后执行如下sql脚本进行数据表创建和数据初始化: -- ------------------------ ...

  9. 案例解析|政府信息化的BI建设应用 .

    一.行业背景 某建设厅综合监管信息化平台,是政企业务协同的平台之一,同时兼具协作.门户.办公应用集成.用户权限管理等多项功能.在此要求基础上,选择中间件基础技术平台,可以在最大程度满足平台功能需求的前 ...

  10. 基础环境系列:PHP7.3.0并连接pache/IIS和MySQL

    版本: php7.3.0 MySQL8.0.12 Apache2.4 IIS8 一.下载PHP  1.下载php3.7 PHP版本:php7.3(7.3.0) 下载地址:https://windows ...