codeforces #578(Div.2)
A. Hotelier
Amugae has a hotel consisting of 1010 rooms. The rooms are numbered from 00 to 99 from left to right.
The hotel has two entrances — one from the left end, and another from the right end. When a customer arrives to the hotel through the left entrance, they are assigned to an empty room closest to the left entrance. Similarly, when a customer arrives at the hotel through the right entrance, they are assigned to an empty room closest to the right entrance.
One day, Amugae lost the room assignment list. Thankfully Amugae's memory is perfect, and he remembers all of the customers: when a customer arrived, from which entrance, and when they left the hotel. Initially the hotel was empty. Write a program that recovers the room assignment list from Amugae's memory.
Input
The first line consists of an integer nn (1≤n≤1051≤n≤105), the number of events in Amugae's memory.
The second line consists of a string of length nn describing the events in chronological order. Each character represents:
- 'L': A customer arrives from the left entrance.
- 'R': A customer arrives from the right entrance.
- '0', '1', ..., '9': The customer in room xx (00, 11, ..., 99 respectively) leaves.
It is guaranteed that there is at least one empty room when a customer arrives, and there is a customer in the room xx when xx (00, 11, ..., 99) is given. Also, all the rooms are initially empty.
Output
In the only line, output the hotel room's assignment status, from room 00 to room 99. Represent an empty room as '0', and an occupied room as '1', without spaces.
Examples
input
8
LLRL1RL1
output
1010000011
input
9
L0L0LLRR9
output
1100000010
Note
In the first example, hotel room's assignment status after each action is as follows.
- First of all, all rooms are empty. Assignment status is 0000000000.
- L: a customer arrives to the hotel through the left entrance. Assignment status is 1000000000.
- L: one more customer from the left entrance. Assignment status is 1100000000.
- R: one more customer from the right entrance. Assignment status is 1100000001.
- L: one more customer from the left entrance. Assignment status is 1110000001.
- 1: the customer in room 11 leaves. Assignment status is 1010000001.
- R: one more customer from the right entrance. Assignment status is 1010000011.
- L: one more customer from the left entrance. Assignment status is 1110000011.
- 1: the customer in room 11 leaves. Assignment status is 1010000011.
So after all, hotel room's final assignment status is 1010000011.
In the second example, hotel room's assignment status after each action is as follows.
- L: a customer arrives to the hotel through the left entrance. Assignment status is 1000000000.
- 0: the customer in room 00 leaves. Assignment status is 0000000000.
- L: a customer arrives to the hotel through the left entrance. Assignment status is 1000000000 again.
- 0: the customer in room 00 leaves. Assignment status is 0000000000.
- L: a customer arrives to the hotel through the left entrance. Assignment status is 1000000000.
- L: one more customer from the left entrance. Assignment status is 1100000000.
- R: one more customer from the right entrance. Assignment status is 1100000001.
- R: one more customer from the right entrance. Assignment status is 1100000011.
- 9: the customer in room 99 leaves. Assignment status is 1100000010.
So after all, hotel room's final assignment status is 1100000010.
题意:10个房间两个门,在左右两端,从那边的门进优先安排进最近的房间,任意客人可以离开房间,n个事件从左进、从右进、客人离开房间。问最后的房间 分布情况。
思路:按照题意模拟即可。如果是哪个房间的客人离开了,利用Ascll码的到数组下标访问数组即可,反之就遍历数组找最近的。代码如下:
#include <bits/stdc++.h>
#define LL long long
using namespace std;
int n,a[10];
string s;
int main(){
cin>>n>>s;
for(int i=0;i<n;i++){
if(s[i]=='L'){for(int j=0;j<10;j++)if(!a[j]){a[j]=1;break;}}
else if(s[i]=='R'){for(int j=9;j>=0;j--)if(!a[j]){a[j]=1;break;}}
else a[s[i]-'0']=0;
}
for(int i=0;i<10;i++)printf("%d",a[i]);
return 0;
}
B. Block Adventure
Gildong is playing a video game called Block Adventure. In Block Adventure, there are nn columns of blocks in a row, and the columns are numbered from 11 to nn. All blocks have equal heights. The height of the ii-th column is represented as hihi, which is the number of blocks stacked in the ii-th column.
Gildong plays the game as a character that can stand only on the top of the columns. At the beginning, the character is standing on the top of the 11-st column. The goal of the game is to move the character to the top of the nn-th column.
The character also has a bag that can hold infinitely many blocks. When the character is on the top of the ii-th column, Gildong can take one of the following three actions as many times as he wants:
- if there is at least one block on the column, remove one block from the top of the ii-th column and put it in the bag;
- if there is at least one block in the bag, take one block out of the bag and place it on the top of the ii-th column;
- if i<ni<n and |hi−hi+1|≤k|hi−hi+1|≤k, move the character to the top of the i+1i+1-st column. kk is a non-negative integer given at the beginning of the game. Note that it is only possible to move to the next column.
In actions of the first two types the character remains in the ii-th column, and the value hihi changes.
The character initially has mm blocks in the bag. Gildong wants to know if it is possible to win the game. Help Gildong find the answer to his question.
Input
Each test contains one or more test cases. The first line contains the number of test cases tt (1≤t≤10001≤t≤1000). Description of the test cases follows.
The first line of each test case contains three integers nn, mm, and kk (1≤n≤1001≤n≤100, 0≤m≤1060≤m≤106, 0≤k≤1060≤k≤106) — the number of columns in the game, the number of blocks in the character's bag at the beginning, and the non-negative integer kk described in the statement.
The second line of each test case contains nn integers. The ii-th integer is hihi (0≤hi≤1060≤hi≤106), the initial height of the ii-th column.
Output
For each test case, print "YES" if it is possible to win the game. Otherwise, print "NO".
You can print each letter in any case (upper or lower).
Example
input
5
3 0 1
4 3 5
3 1 2
1 4 7
4 10 0
10 20 10 20
2 5 5
0 11
1 9 9
99
output
YES
NO
YES
NO
YES
Note
In the first case, Gildong can take one block from the 11-st column, move to the 22-nd column, put the block on the 22-nd column, then move to the 33-rd column.
In the second case, Gildong has to put the block in his bag on the 11-st column to get to the 22-nd column. But it is impossible to get to the 33-rd column because |h2−h3|=3>k|h2−h3|=3>k and there is no way to decrease the gap.
In the fifth case, the character is already on the nn-th column from the start so the game is won instantly.
题意: 小G在玩一款电子游戏。游戏规则是有n列柱子(每列柱子上有若干等高积木)并排放在一起,给定小G的跨越能力k(即他只能站在柱顶,自左向右地走,且两列柱子之间的差值不能大于k)。小G有一个袋子(袋子中的积木数为m,袋子的容量是无限大的),可以进行如下操作,拿起一个积木放进袋子里,从袋子里掏出一个积木置于柱顶。如果小G能走到最后一个柱子的顶端则算他赢,否则算他输。
思路:首先来考虑a[i]>=a[i+1]的情况,此时无论k、m为多少都能走到下一列,在结合k的作用;可以推出a[i]+k>=a[i+1]时也是一定可以走到下一列的,此时应该在保证能够走到下一列的情况下尽可能地把积木装进袋子,继而可以得到一个最低通过高度(a[i+1]-k);反过来的话,则要从袋子里拿出积木以达到最低通过高度。代码如下:
#include <bits/stdc++.h>
#define LL long long
using namespace std;
int const maxn=101;
int n,m,k;
struct node{
int data;
}q[maxn];
bool text()
{
bool qaq=false;
for(int i=0;i<n-1;i++){
if(i==n-2){
if(q[i].data+m+k>=q[i+1].data){//如果走到了最后一列返回真
qaq=true;
break;
}
}
if(q[i].data+k>=q[i+1].data){//如果q[i].data大于当前最小通过高度,就尽可能往及袋子里装积木
if(q[i+1].data>=k){
m+=q[i].data-(q[i+1].data-k);
}else{
m+=q[i].data;
}
}
else{//否则判断加上袋子里的积木能否达到当前最大高度
if(q[i].data+m+k<q[i+1].data)break;
else{
m-=q[i+1].data-k-q[i].data;
if(m<0)break;//这句不加也能过,保险起见还是留着吧
}
}
}
return qaq;
}
int main()
{
int t;
scanf("%d",&t);//测试数据组数
while(t--){
scanf("%d %d %d",&n,&m,&k);
for(int i=0;i<n;i++)scanf("%d",&q[i].data);
if(n==1){//特判下只有1列的情况
printf("YES\n");
continue;
}
if(text())printf("YES\n");
else printf("NO\n");
}
return 0;
}
codeforces #578(Div.2)的更多相关文章
- Codeforces Round #578 (Div. 2)
Codeforces Round #578 (Div. 2) 传送门 A. Hotelier 暴力即可. Code #include <bits/stdc++.h> using names ...
- Codeforces #344 Div.2
Codeforces #344 Div.2 Interview 题目描述:求两个序列的子序列或操作的和的最大值 solution 签到题 时间复杂度:\(O(n^2)\) Print Check 题目 ...
- Codeforces #345 Div.1
Codeforces #345 Div.1 打CF有助于提高做题的正确率. Watchmen 题目描述:求欧拉距离等于曼哈顿距离的点对个数. solution 签到题,其实就是求有多少对点在同一行或同 ...
- Codeforces Beta Round #27 (Codeforces format, Div. 2)
Codeforces Beta Round #27 (Codeforces format, Div. 2) http://codeforces.com/contest/27 A #include< ...
- Codeforces#441 Div.2 四小题
Codeforces#441 Div.2 四小题 链接 A. Trip For Meal 小熊维尼喜欢吃蜂蜜.他每天要在朋友家享用N次蜂蜜 , 朋友A到B家的距离是 a ,A到C家的距离是b ,B到C ...
- codeforces #592(Div.2)
codeforces #592(Div.2) A Pens and Pencils Tomorrow is a difficult day for Polycarp: he has to attend ...
- codeforces #577(Div.2)
codeforces #577(Div.2) A Important Exam A class of students wrote a multiple-choice test. There are ...
- codeforces #332 div 2 D. Spongebob and Squares
http://codeforces.com/contest/599/problem/D 题意:给出总的方格数x,问有多少种不同尺寸的矩形满足题意,输出方案数和长宽(3,5和5,3算两种) 思路:比赛的 ...
- KMP(next数组的更新理解)Codeforces Round #578 (Div. 2)--Compress Words
题目链接:https://codeforc.es/contest/1200/problem/E 题意: 有n串字符串,让你连起来:sample please ease in out ---> ...
随机推荐
- Linux系统中的load average(平均负载/运行队列)
1.load average 的含义 系统负载(System Load)是系统CPU繁忙程度的度量,即有多少进程在等待被CPU调度(进程等待队列的长度) linux系统中的Load对当前CPU工作量的 ...
- Spring管理连接池实验出现错误(c3p0)
配置文件: 测试文件: 出现异常报错:
- 关于使用repo时repo init和repo sync失败的一个解决方案
由于我国的网络的原因,在访问谷歌等一些国外网络资源时经常会遇到被拦截的情况,导致repo等一些代码管理工具拉取代码网络受限受阻,下面提供一个可以参考的简单解决方案. 1.repo init时的遇到fa ...
- xSS-Reflected
反射性(非持久性XSS),藏在URL中 一般用户访问恶意链接执行 Low <?php header ("X-XSS-Protection: 0"); // Is there ...
- 【Spring IoC】IoC容器初始化(二)
Ioc容器的初始化是由refresh()方法来启动的,这个方法标志着Ioc容器的正式启动. 具体来说这个启动过程包括三个基本过程: BeanDefinition的Resource定位 BeanDefi ...
- c++中#ifndef ... 与#pragma once的区别
原文链接:https://www.cnblogs.com/qiang-upc/p/11407364.html (1)C/C++防止头文件被include多次的方法:#ifnde.. 及 #prag ...
- AWS云教育账号创建以及搭建数据库
注册过程繁琐,本文强调关键几点 首先拿到aws的二维码,进入之后填写相关个人信息,用学校邮箱注册,用学校邮箱注册!! 之后审核会有大约10分钟的过程,之后会收到确认邮件 点进去之后就可以设置自己的密码 ...
- ASP.NET Core 中的 依赖注入介绍
ASP.NET Core 依赖注入 HomeController public class HomeController : Controller { private IStudentReposito ...
- ORB-SLAM2初步(跟踪模块)
一.跟踪模块简介 在ORB-SLAM或其他SLAM系统中,跟踪的主要任务是根据相机或视频输入的图像帧实时输出相机位姿.在ORB-SLAM中,跟踪模块的主要任务是实时输出相机位姿和筛选关键帧,完成一个没 ...
- 解决PEnetwork启动的时候提示"An error occured while starting the "TCP/IP Registry Compatibility" Service (2)!"程序将立即退出的问题
解决PEnetwork启动的时候提示"An error occured while starting the "TCP/IP Registry Compatibility" ...