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

娄底网站建设方案济南做seo的公司排名

娄底网站建设方案,济南做seo的公司排名,网站建设要咨询哪些,网站建设上线问题题目描述 给定一个长为 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.tj-hxxt.cn/news/108178.html

相关文章:

  • 配置 tomcat 做网站长沙百度快速排名优化
  • access如何与网站连接数据库口碑营销的特征
  • 租车行网站模版yandex搜索入口
  • 适合医药公司做网站的图片百度营销是什么
  • 金融网站建设内容百度站长平台网站提交
  • 用第三方做网站关键词分类哪八种
  • 安徽专业网站建设创新简阳seo排名优化培训
  • 漏惹网站做seo搜索引擎优化步骤
  • 江苏网站建站系统哪家好怎样推广公司的网站
  • 网站颜色正确搭配实例公司注册
  • 如何搭建一个企业子账号网站手机建立一个免费网站
  • 做围棋题网站站外推广怎么做
  • 无域名建网站南昌网优化seo公司
  • 岗厦网站建设百度一下官网首页下载
  • 做网站路径体育新闻最新消息
  • 聊城阳谷网站建设提升网页优化排名
  • 妙趣网 通辽网站建设营销伎巧第一季
  • 在阿里巴巴上怎样做网站益阳网络推广
  • 西安市网站制作公司seo怎么推广
  • 网站建设分工谷歌seo是什么职业
  • 大连手机自适应网站建设服务宁波seo排名优化哪家好
  • 东莞网站制作电话网络广告设计
  • 茗哥网站建设百度推广费用多少
  • 购物网站模版东营优化公司
  • 建设导航网站适合seo软件
  • 传统网站怎么做前端模块seo实战培训费用
  • 公司网站首页大图怎么做营销策略包括哪些内容
  • 开平 做一网站微博营销软件
  • 宜宾市最新疫情情况宁波专业seo服务
  • 对网站建设的评价外贸推广哪个公司好