题目描述:

众所周知,如今的波兰在很久以前住着很多部落。他们的首都被n座山所环绕,形成一个圆圈。在每一座山上有一个哨兵,他日夜观察附近的山。

如果有任何危险,哨兵会在山上放一把火。如果在连接两座山的圆弧上的任何一座山都不高于这两座山,那么这两座山上的哨兵能相互看到对方。由于任意两座山都有两条不同的圆弧连接他们,所以如果这两条圆弧中的任意一条能满足以上条件,那么信号就可见。例如,对于任意两个相邻的哨兵,他们的信号都是互相可见的。

一个侦查系统的重要特征是能看见对方信号的哨兵的对数。你需要根据给出的山的高度得到这些哨兵的对数。

解题报告:

10WA,用时1h50min

这题做的不是很好,开始我普通的破环成链,写了一个单调队列,然后在其中二分大于当前值的最小值的位置t,然后对答案贡献就是\(r-t+1\),最后发现是有问题的,因为当两个点可以从两边看到时,那么就会统计两次

然后请教大佬,处理重复的方式是去掉序列中最大值,然后把最大值前一段接在后一段,再按我的做法做一遍,然后再统计最大值贡献即可,为什么是对的?

因为答案不可能穿过最大值的位置,除非两边的都等于最大值,既然都等于最大值,那么无论正向反向都可以被统计到,然后就非常简单了.

注意:在统计最大值的贡献时细节很多,本蒟蒻在这里WA了很久..

#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#define RG register
#define il inline
#define iter iterator
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long long ll;
const int N=2e6+5;
int n,a[N],l=1,r=0,q[N],val=0,b[N],tot=0;
int gi(){
int str=0;char ch=getchar();
while(ch>'9' || ch<'0')ch=getchar();
while(ch>='0' && ch<='9')str=(str<<1)+(str<<3)+ch-48,ch=getchar();
return str;
}
int midit(int x){
int L=l,R=r,mid,ret=l;
while(L<=R){
mid=(L+R)>>1;
if(q[mid]>x)ret=mid,L=mid+1;
else R=mid-1;
}
return ret;
}
int c[N];bool d[N];
void work()
{
scanf("%d",&n);
for(int i=1;i<=n;i++){
a[i]=gi();c[i]=a[i];c[i+n]=c[i];
if(a[i]>a[val])val=i;
}
for(int i=val+1;i<=n;i++)
b[++tot]=a[i];
for(int i=1;i<val;i++)
b[++tot]=a[i];
n--;
for(int i=1;i<=n;i++)a[i]=b[i];
int t;ll ans=0;
for(int i=1;i<=n;i++){
if(l<=r){
t=midit(a[i]);
ans+=r-t+1;
}
while(l<=r && a[i]>q[r])r--;
q[++r]=a[i];
}
int mx=0,lim=val+n;n++;
for(int i=val+1;i<=lim;i++){
if((c[i]>=mx && mx<=c[val]) || (i==val+1)){
if(i>n)d[i-n]=true;
else d[i]=true;
mx=c[i];
}
}
mx=0;
for(int i=lim;i>=val+1;i--){
if((c[i]>=mx && mx<=c[val]) || (i==val-1)){
if(i>n)d[i-n]=true;
else d[i]=true;
mx=c[i];
}
}
for(int i=1;i<=n;i++)ans+=d[i];
printf("%lld\n",ans);
} int main()
{
work();
return 0;
}

51Nod 1482 部落信号的更多相关文章

  1. [51nod1482]部落信号 单调栈

    ~~~题面~~~ 题解: 可以发现这是一道单调栈的题目,首先来考虑数字没有重复时如何统计贡献. 因为这是一个环,而如果我们从最高的点把环断开,并把最高点放在链的最后面(顺时针移动),那么因为在最高点两 ...

  2. 【题解】CF#713 E-Sonya Partymaker

    这题真的想了挺久的,然而到最后也还是没想到怎样处理环的情况……网上竟然也完全没有题解,无奈之下到 CF 的 AC 代码里面去找了一份膜拜了一下.感谢~ 由于觉得这题有一定的难度,自己看代码也看了比较久 ...

  3. 51nod A 魔法部落(逆元费马小定理)

    A 魔法部落 小Biu所在的部落是一个魔法部落,部落中一共有n+1个人,小Biu是魔法部落中最菜的,所以他的魔力值为1,魔法部落中n个人的魔法值都不相同,第一个人的魔法值是小Biu的3倍,第二个人的魔 ...

  4. ReactiveCocoa 中 RACSignal 是怎样发送信号

    前言 ReactiveCocoa是一个(第一个?)将函数响应式编程范例带入Objective-C的开源库.ReactiveCocoa是由Josh Abernathy和Justin Spahr-Summ ...

  5. ReactiveCocoa 中 RACSignal 是如何发送信号的

    https://juejin.im/post/5829f4c3570c350063c436ac 前言 ReactiveCocoa是一个(第一个?)将函数响应式编程范例带入Objective-C的开源库 ...

  6. Boost信号/槽signals2

    信号槽是Qt框架中一个重要的部分,主要用来解耦一组互相协作的类,使用起来非常方便.项目中有同事引入了第三方的信号槽机制,其实Boost本身就有信号/槽,而且Boost的模块相对来说更稳定. signa ...

  7. 为什么房间的 Wi-Fi 信号这么差

    最近把家里主卧整成了个小影院,由于之前房子装修时网线端口与电源插口布置太少,导致家庭网络架设变得麻烦起来,最后终于通过「无线中继」技术达到了全屋满格 Wi-Fi 的效果. 在 Wi-Fi 架设过程中, ...

  8. qt5中信号和槽的新语法

    qt5中的连接 有下列几种方式可以连接到信号上 旧语法 qt5将继续支持旧的语法去连接,在QObject对象上定义信号和槽函数,及任何继承QObjec的对象(包含QWidget). connect(s ...

  9. C# - 多线程 之 信号系统

    基础概览 多线程之信号系统命名空间 using System.Threading; 线程同步类的继承层次关系图 终止状态和非终止状态 在终止状态下,被WaitOne()阻塞的线程会逐个得到释放.如果一 ...

随机推荐

  1. Hibernate之深入Hibernate的映射文件

    这周周末 要把hibernate的映射文件搞定 .. 1.映射文件的主结构 主要结构  :根元素为<hibernate-mapping ></hibernate-mapping> ...

  2. SCOI2010 序列操作

    2421 序列操作 http://codevs.cn/problem/2421/ 2010年省队选拔赛四川   题目描述 Description lxhgww最近收到了一个01序列,序列里面包含了n个 ...

  3. 第二篇:Python数据类型

    一.引子 1.什么是数据? x= #是我们要存储的数据 2.为何数据要分不同的类型 数据是用来表示状态的,不同的状态就应该用不同的类型的数据去表示 3.数据类型 数字(整型,长整型,浮点型,复数) 字 ...

  4. MSSQL 2000 错误823恢复

    一.故障描述 MSSQL Server 2000 附加数据库错误823,附加数据库失败.数据库没有备份,不能通过备份恢复数据库,急需恢复数据库中的数据. 二.故障分析SQL Server数据库 823 ...

  5. hadoop基础教程免费分享

    提起Hadoop相信大家还是很陌生的,但大数据呢?大数据可是红遍每一个角落,大数据的到来为我们社会带来三方面变革:思维变革.商业变革.管理变革,各行业将大数据纳入企业日常配置已成必然之势.阿里巴巴创办 ...

  6. Ubuntu安装使用latex

    TeX Live is a TeX distribution to get up and running with the TeX document production system. To ins ...

  7. ASCII排序

    ASCII码排序 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符.   输入 第一行输 ...

  8. phalcon框架命名空间

    命名空间第一影像就是实际上就相当宏定义,就是需要把一个很长的带有路径的类文件指定一个空间,然后就可直接用简单简写模式 当然如果是外部文件需要首先引入外部文件,如果不引入外部文件还是会报错.一般最会出错 ...

  9. Python内置函数(37)——sorted

    英文文档: sorted(iterable[, key][, reverse]) Return a new sorted list from the items in iterable. Has tw ...

  10. Linux CentOS7.0 (03)安装验证 docker

    一.安装docker 1.升级 Linux 的软件包和内核 sudo yum update 2.安装 docker (1) sudo yum install docker  (2).验证docker安 ...