当前位置: 首页 > news >正文

虚拟币网站建设网络营销广告名词解释

虚拟币网站建设,网络营销广告名词解释,广州新闻热点事件,如何让百度不收录网站题目描述 给定一个长为 nnn 的序列 a1,…,ana_1,\ldots,a_na1​,…,an​,其中对于任意的 iii 满足 1≤ai≤n1 \leq a_i \leq n1≤ai​≤n。 定义一个二元组函数如下: f((l,r))(min⁡{al,…,ar},max⁡{al,…,ar})(l≤r)f((l,r))(\min\{a_l,\ldots,a_r\}…

题目描述

给定一个长为 nnn 的序列 a1,…,ana_1,\ldots,a_na1,,an,其中对于任意的 iii 满足 1≤ai≤n1 \leq a_i \leq n1ain

定义一个二元组函数如下:
f((l,r))=(min⁡{al,…,ar},max⁡{al,…,ar})(l≤r)f((l,r))=(\min\{a_l,\ldots,a_r\},\max\{a_l,\ldots,a_r\})(l \leq r)f((l,r))=(min{al,,ar},max{al,,ar})(lr)

你需要回答 qqq 次询问,每次给定 (li,ri)(l_i,r_i)(li,ri),问其最少经过多少次 fff 的调用(即 (l,r)→f((l,r))(l,r) \rightarrow f((l,r))(l,r)f((l,r)))使得 (li,ri)(l_i,r_i)(li,ri) 变成 (1,n)(1,n)(1,n),若无解请输出 -1

题解

智慧的性质题
首先注意到f((l,r))=⋃i=lr−1f((i,i+1))f((l,r))=\bigcup_{i=l}^{r-1}f((i,i+1))f((l,r))=i=lr1f((i,i+1))
发现可以推广到fk((l,r))=⋃i=lr−1fk((i,i+1))f^k((l,r))=\bigcup_{i=l}^{r-1}f^k((i,i+1))fk((l,r))=i=lr1fk((i,i+1)),可以用归纳法证明
接下来的做法就容易可以想出了
Fi,j=f2i((j,j+1))F_{i,j}=f^{2^i}((j,j+1))Fi,j=f2i((j,j+1)),然后倍增解决,合并区间可以用线段树,长度为111的线段需要特别处理

code\text{code}code

#include<cstdio>
#include<algorithm>
#define ll long long
using namespace std;
void read(int &res)
{res=0;char ch=getchar();while(ch<'0'||ch>'9') ch=getchar();while('0'<=ch&&ch<='9') res=(res<<1)+(res<<3)+(ch^48),ch=getchar();
}
const int N=1e5+100,B=40;
int n,q,a[N+10];
struct seg
{int l,r;
}f[B+10][N+10];
int g[B+10][N+10];
seg merge(seg a,seg b){return (seg){min(a.l,b.l),max(a.r,b.r)};}
struct SEG
{seg t[N<<2|1];#define ls (p<<1)#define rs (p<<1|1)#define mid ((l+r)>>1)void build(seg *f,int p=1,int l=1,int r=n-1){if(l==r){t[p]=f[l];return;}build(f,ls,l,mid),build(f,rs,mid+1,r);t[p]=merge(t[ls],t[rs]);}seg query(int L,int R,int p=1,int l=1,int r=n-1){if(L<=l&&r<=R) return t[p];if(R<=mid) return query(L,R,ls,l,mid);else if(L>mid) return query(L,R,rs,mid+1,r);else return merge(query(L,R,ls,l,mid),query(L,R,rs,mid+1,r));}#undef ls#undef rs#undef mid
}t[B+10];
int main()
{
//	freopen("a.in","r",stdin);read(n),read(q);if(n==1){for(;q--;) printf("0\n");return 0;}for(int i=1;i<=n;i++) read(a[i]);for(int i=1;i<n;i++) f[0][i]=(seg){min(a[i],a[i+1]),max(a[i],a[i+1])},g[0][i]=a[i];t[0].build(f[0]);for(int j=1;j<=B;j++){for(int i=1;i<n;i++){if(f[j-1][i].l==f[j-1][i].r) f[j][i]=(seg){g[j-1][f[j-1][i].l],g[j-1][f[j-1][i].l]};else f[j][i]=t[j-1].query(f[j-1][i].l,f[j-1][i].r-1);}t[j].build(f[j]);for(int i=1;i<=n;i++) g[j][i]=g[j-1][g[j-1][i]];}for(int l,r;q--;){read(l),read(r);if(l==1&&r==n){printf("0\n");continue;}ll ans=0;if(l!=r)for(int i=B;i>=0;i--){seg tmp=t[i].query(l,r-1);if(tmp.l!=1||tmp.r!=n){l=tmp.l,r=tmp.r;ans+=(1ll<<i);}if(l==r) break;}if(l==r) printf("-1\n");else{seg tmp=t[0].query(l,r-1);if(tmp.l==1&&tmp.r==n) printf("%lld\n",ans+1);else printf("-1\n");}}return 0;
}
http://www.hengruixuexiao.com/news/33089.html

相关文章:

  • 免费1级做爰片在线网站百度度小店申请入口
  • 承德微网站建设自助网站建设
  • 专业做域名的网站吗bt磁力搜索器
  • 网站上动画视频怎么做360收录批量查询
  • app手机网站制作搜索量查询百度指数
  • 网站建设运作流程站长统计推荐
  • 网站建设运营预算明细什么是引流推广
  • 建站技巧免费seo视频教程
  • 网站源码本地测试小程序定制
  • 一级a做爰片免费网站 视频最知名的网站推广公司
  • 17做网店这个网站好不好百度企业
  • 鄂州做网站报价学电商出来一般干什么工作
  • 网站开发的软件有哪些做网站seo推广公司
  • 石家庄知名网站建设信息流推广方式
  • 日照网站建设费用公众号如何推广引流
  • 柳州网站制作全国新冠疫情最新情况
  • 找兼职做网站建设千锋教育官方网
  • 百度做网站电话多少钱个人域名注册流程
  • wordpress 端口映射seo职位招聘
  • 门户网站开发工作室上海seo公司
  • 网站建设模板自助建站系统开发
  • 营销型网站建设公司提供网站建设百度学术官网
  • 马蜂窝网站建设目的设计网站都有哪些
  • 网站公示如何做链接广州seo服务公司
  • 有域名了网站怎么做优秀的营销案例
  • 威海网站建设是什么淘宝店铺运营推广
  • 自己做传奇网站百度官网认证免费
  • 专门做网站建设的公司网络营销策略有哪些
  • 佛山信息科技有限公司石狮seo
  • 网站评论做外链流量平台有哪些