NOIP模拟测试29「爬山·学数数·七十和十七」
爬山题解不想写了
学数数

离散化然后找到以每一个值为最大值的连续子段有多少个,然后开个桶维护
那么怎么找以每一个值为最大值的连续子段个数
方法1(我的极笨的方法)
考试时我的丑陋思路,
定义极左值为左面第一个大于当前值的值,极右值为右面第一个大于当前值的值
,找到最大值然后当前符合的子段个数就为$r-l+1+(r-now)*(now-l)$
解释一下$r-l+1$为以$now$为边界的子段,$(r-now)*(now-l)$为包含$now$的子段
那么问题又转化为了如何求边界
我们发现找极左值,极右值过程可以二分实现,
我们每次找到最大值,然后找到左右子段的最大值和$id$,这些子段的最大值边界就是当前$now$!!!!
维护最大值$id$可以线段树实现
给一下实现
简单好想个屁嘞
但是比较直观是真的
void pre(ll l,ll r,ll now,ll nowmax){
if(l>r) return ;
if(l==r) {
sum[nowmax]++;
return ;
}
sum[nowmax]+=r-l+1+(r-now)*(now-l);
maxn=0,ida=0;
if(l<=now-1)
{
seg_max(1,l,now-1);
pre(l,now-1,ida,maxn);
}
maxn=0,ida=0;
if(now+1<=r)
{
seg_max(1,now+1,r);
pre(now+1,r,ida,maxn);
}
}
总代码
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define A 2222222
ll n,q,mx,mn=0x7fffffffff,ida,maxn,idb;
ll a[A],sum[A],b[A];
char c[10];
struct tree{
ll l,r,val,id;
}tr[A];
void pushup(ll p){
if(tr[p<<1].val>tr[p<<1|1].val){
tr[p].val=tr[p<<1].val;
tr[p].id=tr[p<<1].id;
}
else {
tr[p].val=tr[p<<1|1].val;
tr[p].id=tr[p<<1|1].id;
}
}
void built(ll p,ll l,ll r){
tr[p].l=l,tr[p].r=r;
if(l==r){
tr[p].val=a[l];
tr[p].id=l;
return ;
}
ll mid=(l+r)>>1;
built(p<<1,l,mid);
built(p<<1|1,mid+1,r);
pushup(p);
}
void seg_max(ll p,ll l,ll r){
// printf("p=%lld l=%lld r=%lld l=%lld r=%lld\n",p,l,r,tr[p].l,tr[p].r);
if(tr[p].l>=l&&tr[p].r<=r){
if(tr[p].val>maxn){
maxn=tr[p].val;
ida=tr[p].id;
}
return ;
}
ll mid=(tr[p].l+tr[p].r)>>1;
if(mid>=l)
seg_max(p<<1,l,r);
if(mid<r)
seg_max(p<<1|1,l,r);
}
void pre(ll l,ll r,ll now,ll nowmax){
if(l>r) return ;
if(l==r) {
sum[nowmax]++;
// printf("l=%lld nowmax=%lld \n",l,nowmax);
return ;
}
// printf("l=%lld r=%lld nowmax=%lld r-l=%lld\n",l,r,nowmax,r-l+1);
sum[nowmax]+=r-l+1+(r-now)*(now-l);
maxn=0,ida=0;
if(l<=now-1)
{
seg_max(1,l,now-1);
pre(l,now-1,ida,maxn);
}
maxn=0,ida=0;
if(now+1<=r)
{
seg_max(1,now+1,r);
pre(now+1,r,ida,maxn);
}
}
int main(){
scanf("%lld%lld",&n,&q);
for(ll i=1;i<=n;i++){
scanf("%lld",&a[i]);
b[i]=a[i];
if(a[i]>mx){
ida=i;
mx=a[i];
}
mn=min(mn,a[i]);
}
sort(b+1,b+n+1);
ll m=unique(b+1,b+n+1)-b-1;
// for(ll i=1;i<=m;i++){
// printf("b=%lld\n",b[i]);
// }
for(ll i=1;i<=n;i++)
a[i]=lower_bound(b+1,b+1+m,a[i])-b;
built(1,1,n);
pre(1,n,ida,a[ida]);
for(ll i=1;i<=n;i++)
sum[i]+=sum[i-1];
for(ll i=1,que;i<=q;i++){
scanf("%s",c+1);
scanf("%lld",&que);
ll nxt=(lower_bound(b+1,b+m+1,que)-b),
pre=(upper_bound(b+1,b+m+1,que))-b-1;
// printf("pre=%lld nxt=%lld\n",pre,nxt);
if(c[1]=='<'){
if(que>mx){
printf("%lld\n",sum[n]);
continue ;
}
if(que<mn){
printf("0\n");
continue ;
}
if(pre!=nxt)
printf("%lld\n",sum[pre]);
else printf("%lld\n",sum[pre-1]);
}
else if(c[1]=='='){
if(que>mx||que<mn){
printf("0\n");
continue ;
}
if(pre==nxt)
printf("%lld\n",sum[pre]-sum[pre-1]);
else printf("0\n");
}
else if(c[1]=='>'){
if(que>mx){
printf("0\n");
continue ;
}
if(que<mn){
printf("%lld\n",sum[n]);
continue ;
}
if(pre==nxt)
printf("%lld\n",sum[n]-sum[pre]);
else printf("%lld\n",sum[n]-sum[pre]);
}
}
}
方法2
单调栈,显然可以单调栈,看到这个就必须想单调栈啊!
维护一个单调下降的栈当发现当前值比队尾小接着插,发现当前值不小$pop$,当前值的$l$就是$pop$后单调栈的栈顶,已经$pop$掉的值的$r$就是当前值

代码咕了
七十和十七
设$g[i]$为将相对大小为$i$的数插到队头要花多少步复原
注意是相对大小
以下说的1,2...都是相对大小
我们将$1$移到队头要$1$步复原,$g[1]=1$
将$2$移到队头你相对大小为$1$的也要复原$g[2]=g[1]+1$
将$3$移到队头你大小$1,2$也要复原$g[3]=g[2]+g[1]+1$
...类推
$g[n]=\sum\limits {i=1}^{i<=n-1}(g[i])+1$
然后我们设$f$为移动总步数
$f[i]=f[i-1](为1的情况)+\sum\limits_{j=1}^{j<=i-1} f[i-1]+(i-1)!*g[j]$
,最后再同时除以$i!$,为了方便我们设$E[i]=\frac{f[i]}{i!}$
原式变为$E[i]=E[i-1]+\frac{2^{i-1}-1}{i}$
我们化简移项等操作$xjb$搞就$AC$了
NOIP模拟测试29「爬山·学数数·七十和十七」的更多相关文章
- 8.22 NOIP模拟测试29(B) 爬山+学数数+七十和十七
T1 爬山 二分最高高度,$O(1)$判断是否可行. #include<iostream> #include<cstdio> #define ll long long usin ...
- NOIP模拟测试3「序列·熟练剖分·建造游乐园(play)」
---恢复内容开始--- 序列 刚调出来样例就A了,假装是水题. 因为是乱序,我们要求出来每两项之间最小公比,而不是直接比 求出来每两项之间最小公比,然后扫一遍就完了.(还要注意重复情况) 那么问题就 ...
- NOIP模拟测试19「count·dinner·chess」
反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...
- 20190803 NOIP模拟测试12「斐波那契(fibonacci)· 数颜色 · 分组 」
164分 rank11/64 这次考的不算太差,但是并没有多大的可能性反超(只比一小部分人高十几分而已),时间分配还是不均,T2两个半小时,T1半个小时,T3-额十几分钟吧 然额付出总是与回报成反比的 ...
- NOIP模拟测试10「大佬·辣鸡·模板」
大佬 显然假期望 我奇思妙想出了一个式子$f[i]=f[i-1]+\sum\limits_{j=1}^{j<=m} C_{k \times j}^{k}\times w[j]$ 然后一想不对得容 ...
- NOIP模拟测试29(A)
T1: 题目大意:有一张有向无环图,第$x$次经过边$i$的代价为$a_ix+b_i$,最多经过$c_i$次,起点为1,$s$个点可作为终点,求走$k$次的最小代价. 我们新建一个汇点,将所有可做为终 ...
- NOIP模拟测试38「金·斯诺·赤」
金 辗转相减见祖宗 高精 #include<bits/stdc++.h> using namespace std; #define A 2000 #define P 1 #define N ...
- NOIP模拟测试30「return·one·magic」
magic 题解 首先原式指数肯定会爆$long$ $long$ 首先根据欧拉定理我们可以将原式换成$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G ...
- NOIP模拟测试25「字符串·乌鸦喝水·所陀门王的宝藏(陀螺王)」
字符串 题解 没看出catalan怎么办 dp打表啊! 考虑大力dp拿到30分好成绩!顺便收获一张表 打表发现$C_{n+m}^{m}-C_{n+m}^{m-1}$ 仔细观察然后发现其实就是之前的网格 ...
随机推荐
- 逆向工程初步160个crackme-------7
这两天有点发烧,被这个疫情搞得人心惶惶的.我们这里是小镇平常过年的时候人来人往的,今年就显得格外的冷清.这是老天帮让在家学习啊,破解完这个crackme明天就去接着看我的加密解密,算了算没几天就开学了 ...
- 按照自己的思路研究Spring AOP源码【2】
目录 问题的提出 哪一步导致了顺序的改变 AbstractAdvisorAutoProxyCreator.sortAdvisors()方法 总结 问题的提出 上面这篇文章介绍了Spring AOP源码 ...
- spring-第三章-jdbc
一,回顾 aop:面向切面编程,就是将一些和主业务流程没有关系的公共代码,提取封装到切面类,通过切入点规则,可以对目标方法进行功能增强;也就是可以再目标方法执行的前后添加一段额外逻辑代码; 二,Jdb ...
- ThreadLocal内存溢出代码演示和原因分析!
ThreadLocal 翻译成中文是线程本地变量的意思,也就是说它是线程中的私有变量,每个线程只能操作自己的私有变量,所以不会造成线程不安全的问题. 线程不安全是指,多个线程在同一时刻对同一个全局 ...
- istio部署问题Q&A
端口绑定无权限 创建Gateway,提示绑定端口无权限. 2020-12-27T12:25:30.974288Z warning envoy config gRPC config for type.g ...
- 桌面支持qt版本是多少检查
桌面支持qt版本是多少 # rpm -qa |grep qt |grep 3 |sortqt3-3.3.8b-60.nd7.2.x86_64qt-4.8.6-13.nd7.3.x86_64qt5-qt ...
- shell脚本 在后台执行de 命令 >> 文件 2>&1 将标准输出与错误输出共同写入到文件中(追加到原有内容的后面)
命令 >> 文件 2>&1或命令 &>> 文件 将标准输出与错误输出共同写入到文件中(追加到原有内容的后面) # ll >>aaa 2> ...
- 如何对你的Linux系统进行基准测试: 3开源基准测试工具
如何对你的Linux系统进行基准测试: 3开源基准测试工具 0 赞0 评论 文章标签:SYS Source benchmark tool 开源 基准 系统 linux实用程序的 ...
- 攻防世界(四)php_rce
攻防世界系列:php_rce 1.打开题目 看到这个还是很懵的,点开任意连接都是真实的场景. 2.ThinkPHP5,这里我们需要知道它存在 远程代码执行的漏洞. ?s=index/\think\ap ...
- REST 架构风格详解
什么是 REST 架构风格 REST(Representational State Transfer)是表述性状态转移.分布式超媒体软件的一种架构风格,它基于使用 HTTP.URI 等现有的广泛流行的 ...