题目背景

有很多超级英雄:蝙蝠侠,蜘蛛侠,超人等。其中,有一位叫牛。今天他想模仿蜘蛛侠,所以他选择了一排高大的摩天楼来跳。

题目描述

具体而言,他选择了一个由 N 个摩天大楼构成的序 列,从左到右编号从 1 到 N.他最初位于第 K 座摩天大厦。不幸的是,这样的他的能力有限,所以只能向左或向右跳到相邻的摩天楼,只有那些摩天大楼的高度不大于他目前的摩天大楼 的高度的楼房才行。然而,他使蹦床上一些摩天大楼,从这些摩天大厦,他可以跳到任何其 他的摩天大楼,无论多么高以及位置在何处。 找出从第 K 座楼房开始,他能跳到的最多的不同的楼房数。如果一个楼房被多次访问,我 们只计算一次。楼房 K 也被计算在内,不管我们是否回到过楼房 K。

输入输出格式

输入格式:

第一行,包含两个数N和 K (3 ≤ N ≤ 300 000, 1 ≤ K ≤ N),表示楼房总数和开始的楼
房。
第二行N个数,均小于 10^6,从左到右依次表示楼房的高度。
第三行N个字符'.' 或'T'.如果第 i 个字符是'T',表示这里有一个蹦床在第 i 个楼房。

输出格式:

一个数,有示最多能到的楼房数。

输入输出样例

输入样例#1:

6 4
12 16 16 16 14 14
.T....
输出样例#1:

5
输入样例#2:

10 1
10 7 3 1 1 9 8 2 4 10
..T..T....
输出样例#2:

7

说明

样例 2 线路如下: 1 –>2 –>3 –>6 –>10 –>9 –>8.

Solution:

  本题贪心+模拟。

  从一个位置出发,要么先往左走,要么先往右走,我们分别递推处理出每个点往左和往右能访问的最多的点数,同时对于能到达有$T$位置的点,等价于当前位置也能到任意点,于是把它的位置也标记为$T$。

  然后分情况讨论:

  若第$k$位位置为$T$,那么统计$T$的个数,并记录非$T$位置向左或向右能到达的最多点数,答案就是两者累加(注意:不必考虑两者有重复点的情况,因为我们对于能到达$T$的点都标记为$T$了)。

  若第$k$位位置不为$T$,因为等高可以互达,那么先统计与$k$等高的位置最多往两边扩展多少,答案就是扩展的长度+两边界分别向左向右能到达的最多点数。

代码:

/*Code by 520 -- 9.5*/
#include<bits/stdc++.h>
#define il inline
#define ll long long
#define RE register
#define For(i,a,b) for(RE int (i)=(a);(i)<=(b);(i)++)
#define Bor(i,a,b) for(RE int (i)=(b);(i)>=(a);(i)--)
using namespace std;
const int N=;
int n,k,h[N],lf[N],rt[N],maxn[N];
char t[N]; int main(){
scanf("%d%d",&n,&k);
For(i,,n) scanf("%d",h+i);
scanf("%s",t+);
For(i,,n) if(h[i]>=h[i-]){
if(t[i-]=='T')t[i]='T';
lf[i]=lf[i-]+;
}
Bor(i,,n-) if(h[i]>=h[i+]){
if(t[i+]=='T')t[i]='T';
rt[i]=rt[i+]+;
}
int T=,best=;
For(i,,n)
if(t[i]=='T')++T;
else best=max(best,max(lf[i],rt[i])+);
if(t[k]=='T')printf("%d\n",T+best),exit();
int l=k,r=k;
while(l>&&h[l-]==h[k])l--;
while(r<n&&h[r+]==h[k])r++;
printf("%d\n",r-l++max(lf[l],rt[r]));
return ;
}

P4611 [COCI2011-2012#7] TRAMPOLIN的更多相关文章

  1. Windows server 2012 添加中文语言包(英文转为中文)(离线)

    Windows server 2012 添加中文语言包(英文转为中文)(离线) 相关资料: 公司环境:亚马孙aws虚拟机 英文版Windows2012 中文SQL Server2012安装包,需要安装 ...

  2. Windows Server 2012 NIC Teaming介绍及注意事项

    Windows Server 2012 NIC Teaming介绍及注意事项 转载自:http://www.it165.net/os/html/201303/4799.html Windows Ser ...

  3. 1.初始Windows Server 2012 R2 Hyper-V + 系统安装详细

    干啥的?现在企业服务器都是分开的,比如图片服务器,数据库服务器,redis服务器等等,或多或少一个网站都会用到多个服务器,而服务器的成本很高,要是动不动采购几十台,公司绝对吃不消的,于是虚拟化技术出来 ...

  4. 0.Win8.1,Win10,Windows Server 2012 安装 Net Framework 3.5

    后期会在博客首发更新:http://dnt.dkill.net 网站部署之~Windows Server | 本地部署:http://www.cnblogs.com/dunitian/p/482280 ...

  5. windows 2012 r2 can't find kb2919355

    问题   解决: 1.手动安装了 Windows8.1-KB2919442-x64 2.手动下载 KB2919355 更新成功     Turns out to have been a result ...

  6. Windows Server 2012 磁盘管理之 简单卷、跨区卷、带区卷、镜像卷和RAID-5卷

    今天给客户配置故障转移群集,在Windows Server 2012 R2的系统上,通过iSCSI连接上DELL的SAN存储后,在磁盘管理里面发现可以新建 简单卷.跨区卷.带区卷.镜像卷.RAID-5 ...

  7. VMware下Windows Server 2012添加新磁盘

    系统管理员在VM下新装了一台Windows Server 2012服务器,我在上面安装了SQL Server 2014 Standard版数据库,安装之初,只分配了一个C盘,我想在这台服务器上添加了三 ...

  8. 在Windows Server 2012中如何快速开关桌面上经典的“计算机、我的文档”等通用图标

    我们都知道,在Windows Server 2012系列的服务器版本中都已经引入了Modern的现代界面作为默认的用户交互界面,同时满足视觉一致化,新版的服务器管理程序也做成了扁平化.因此传统的计算机 ...

  9. VmWare平台Windows Server 2012 无响应宕机

    我们生产服务器都部署在VMware ESXi 5.5平台上,最近大半年的时间,偶尔就会出现操作系统为Windows Servre 2012的服务器出现没有任何响应(unresponsive)的情况,出 ...

随机推荐

  1. python中函数的定义和详细的使用方法

    1. 函数的概念,函数是将具有独立功能的代码块组织成为一个整体,使其具有特殊功能的代码集   2. 函数的作用,使用函数可以加强代码的复用性,提高程序编写的效率   3. 函数的使用,函数必须先创建才 ...

  2. 使用Chrome控制台进行3D模型编辑的尝试

    前言:3D模型编辑的核心是对顶点位置和纹理颜色的编辑,这个研究的目的在于寻找一种通过编程方式直接对模型进行编辑的方法,这种编辑方法和时下流行的通过鼠标点选.拖拽进行编辑的方法之间的关系,和前端编程中“ ...

  3. Siki_Unity_7-4_高自由度沙盘游戏地图生成_MineCraft_Uniblocks插件(可拓展)

    Unity 7-4 高自由度沙盘游戏地图生成 MineCraft (插件Uniblocks) 任务1&2&3&4 素材 && 课程演示 && 课 ...

  4. MYSQL 数据库结构优化

    数据库结构优化 优化数据大小 使表占用尽量少的磁盘空间.减少磁盘I/O次数及读取数据量是提升性能的基础原则.表越小,数据读写处理时则需要更少的内存,同时,小表的索引占用也相对小,索引处理也更加快速. ...

  5. 前端常见算法面试题之 - 从尾到头打印链表[JavaScript解法]

    题目描述 输入一个链表的头结点,从尾到头反过来打印出每个结点的值 实现思路 前端工程师看到这个题目,直接想到的就是,写个while循环来遍历链表,在循环中把节点的值存储在数组中,最后在把数组倒序后,遍 ...

  6. MD5加密--项目案例

    在项目中最尝使用MD5这种非对称加密的就是用户信息登录了.下面我就以一个简单的登录案例来说明MD5的用法 首先来看几张图: 用户登录页:需要选择要登录的系统,同时输入用户的用户名和密码,验证码才能进入 ...

  7. spring boot 配置全局日期类型转换器

    1. 首先自定义一个类型转换器 import org.springframework.core.convert.converter.Converter; import org.springframew ...

  8. java事物详解

    一.什么是Java事务 通常的观念认为,事务仅与数据库相关. 事务必须服从ISO/IEC所制定的ACID原则.ACID是原子性(atomicity).一致性(consistency).隔离性 (iso ...

  9. python—启动自带shell时报错(丢失api-ms-win-crt-runtime-l1-1-0.dll)已解决

    备注: 有的伙伴安装完1后重启,问题可以解决,summer儿在安装完1依然未能解决,于是又进行了2的安装再次重启后问题解决!! 1,安装vc-redist.x64,微软官网搜索免费下载,安装后重启. ...

  10. 机器学习算法 --- SVM (Support Vector Machine)

    一.SVM的简介 SVM(Support Vector Machine,中文名:支持向量机),是一种非常常用的机器学习分类算法,也是在传统机器学习(在以神经网络为主的深度学习出现以前)中一种非常牛X的 ...