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

站酷设计网页版对网站进行seo优化

站酷设计网页版,对网站进行seo优化,微信小程序商城源代码,重庆网站建设制作设计题目大意 小 C C C有一个括号序列 A A A,其长度为 m m m,且序列元素只包含左右括号。他想生成一个无限长的括号序列 B B B,由于 B B B的长度为正无穷,所以其下标可以为任意整数(可以为负)。为了由 A A A生…

题目大意

C C C有一个括号序列 A A A,其长度为 m m m,且序列元素只包含左右括号。他想生成一个无限长的括号序列 B B B,由于 B B B的长度为正无穷,所以其下标可以为任意整数(可以为负)。为了由 A A A生成 B B B,小 C C C采用如下方式:

{ b i = a i , 0 ≤ i < n b i = b i − n , i ≥ n b i = b i + n , i < 0 \begin{cases} b_i=a_i,\qquad 0\leq i<n \\ b_i=b_{i-n},\quad \ i\geq n \\ b_i=b_{i+n},\quad \ i<0 \end{cases} bi=ai,0i<nbi=bin, inbi=bi+n, i<0

无聊的小 C C C还打算以序列 B B B为基础生成无穷个长度为正无穷的括号序列,我们定义 B k B^k Bk代表第 k k k个无穷序列, B 0 = B B^0=B B0=B。对于任意 k ≥ 1 k\geq 1 k1,由 B k − 1 B^{k-1} Bk1生成 B k B^k Bk的方式如下:

{ b i k = b i + 1 k − 1 , b i k − 1 = ‘ ( ’ b i k = b i − 1 k − 1 , b i k − 1 = ‘ ) ’ \begin{cases} b_i^k=b_{i+1}^{k-1}, \quad b_i^{k-1}=‘(’ \\ b_i^k=b_{i-1}^{k-1}, \quad b_i^{k-1}=‘)’ \end{cases} {bik=bi+1k1,bik1=(bik=bi1k1,bik1=)

最后,小 C C C q q q次询问,每次询问给定的 k , l , r k,l,r k,l,r,求有多少个左括号存在于无穷括号序列 B k B^k Bk中下标位于 [ l , r ] [l,r] [l,r]的元素中。

T T T组数据。

1 ≤ n , q ≤ 1 0 5 , 0 ≤ k ≤ 1 0 9 , − 1 0 9 ≤ l ≤ r ≤ 1 0 9 , 1 ≤ T ≤ 10 1\leq n,q\leq 10^5,0\leq k\leq 10^9,-10^9\leq l\leq r\leq 10^9,1\leq T\leq 10 1n,q105,0k109,109lr109,1T10

时间限制 3000 m s 3000ms 3000ms,空间限制 512 M B 512MB 512MB


题解

f ( k , i ) f(k,i) f(k,i)表示 B k B^k Bk中第 i i i个左括号的下标( i i i可以为 0 0 0甚至负数),设 g ( k , p ) g(k,p) g(k,p)表示满足 f ( k , i ) ≤ p f(k,i)\leq p f(k,i)p的最大的 i i i,则区间 [ l , r ] [l,r] [l,r]里的左括号的总数为 g ( k , r ) − g ( k , l − 1 ) g(k,r)-g(k,l-1) g(k,r)g(k,l1) g g g的值可以用二分求出。

因为我们只关心 g g g的差值,所以第 0 0 0个左括号的位置对应那个左括号其实是可以任意指定的。方便起见,我们把括号序列 A A A中的第一个左括号设为第 0 0 0个左括号。

下面考虑 f ( k , i ) f(k,i) f(k,i)的转移式:

  • 如果 f ( k − 1 , i ) f(k-1,i) f(k1,i)的下一个字符为右括号,因为 ( ) () ()会变成 ) ( )( )(,所以 f ( k , i ) = f ( k − 1 , i ) + 1 f(k,i)=f(k-1,i)+1 f(k,i)=f(k1,i)+1
  • 如果 f ( k − 1 , i ) f(k-1,i) f(k1,i)的下一个字符为右括号,因为 ( ( (( ((会变成 ( ∗ (* (,所以 f ( k , i ) = f ( k − 1 , i + 1 ) − 1 f(k,i)=f(k-1,i+1)-1 f(k,i)=f(k1,i+1)1

那么,转移式为

f ( k , i ) = min ⁡ { f ( k − 1 , i ) + 1 , f ( k − 1 , i + 1 ) − 1 } f(k,i)=\min\{f(k-1,i)+1,f(k-1,i+1)-1\} f(k,i)=min{f(k1,i)+1,f(k1,i+1)1}

假设 f ( k , i ) f(k,i) f(k,i)是从 f ( 0 , j ) f(0,j) f(0,j)转移过来的,那么第一维从 0 0 0走到 k k k的过程中, min ⁡ \min min中的第二项恰好选了 j − i j-i ji次,第一项恰好选了 k − ( j − i ) k-(j-i) k(ji)次,所以转移式还可以写为

f ( k , i ) = min ⁡ i ≤ j ≤ i + k { f ( 0 , j ) + k − 2 ( j − i ) } f(k,i)=\min\limits_{i\leq j\leq i+k}\{f(0,j)+k-2(j-i)\} f(k,i)=iji+kmin{f(0,j)+k2(ji)}

可以看出决策区间的大小为 k k k。设括号序列 A A A中,左括号的数量为 m m m,我们先分析 k ≤ m k\leq m km时如何求解。

F ( j ) = f ( 0 , j ) − 2 j F(j)=f(0,j)-2j F(j)=f(0,j)2j,注意到 f ( 0 , j + m ) − f ( 0 , j ) = n f(0,j+m)-f(0,j)=n f(0,j+m)f(0,j)=n,则有

F ( j + t ) = F ( j % m + t ) + ( n − 2 m ) × ⌊ j m ⌋ F(j+t)=F(j\% m+t)+(n-2m)\times \lfloor\dfrac jm\rfloor F(j+t)=F(j%m+t)+(n2m)×mj

其中 t t t是任意非负整数。我们可以用 R M Q RMQ RMQ来预处理 F ( 0 ) F(0) F(0) F ( 2 m − 1 ) F(2m-1) F(2m1),然后把 [ i , i + k ] [i,i+k] [i,i+k]映射到 [ i % m , i % m + k ] [i\%m,i\%m+k] [i%m,i%m+k]求最小值即可。

接下来分析一下 k k k比较大的解法。讨论 n − 2 × m n-2\times m n2×m的值:

  • 如果 n − 2 × m ≥ 0 n-2\times m\geq 0 n2×m0,说明 F ( j + m ) ≥ f ( j ) F(j+m)\geq f(j) F(j+m)f(j),因此最小值只存在于 i ≤ j < i + m i\leq j<i+m ij<i+m这个范围中
  • 如果 n − 2 × m < 0 n-2\times m<0 n2×m<0,说明 F ( j + m ) < f ( j ) F(j+m)<f(j) F(j+m)<f(j),因此最小值只存在于 i + k − m < j ≤ i + k i+k-m<j\leq i+k i+km<ji+k这个范围中

这样,我们就把区间长度缩小到了 m m m,通过与上面类似的方法,用 R M Q RMQ RMQ求最小值即可。

时间复杂度为 O ( ∑ ( n log ⁡ n + q log ⁡ v ) ) O(\sum(n\log n+q\log v)) O((nlogn+qlogv)),其中 v v v表示 l , r l,r l,r的值域。

可以参考代码帮助理解。

卡常小技巧

如果你 TLE \text{TLE} TLE的话,可以参考一下下面这些卡常小技巧:

  • 加上快读
  • 在将当前区间映射在 [ 0 , 2 m − 1 ] [0,2m-1] [0,2m1]上时,因为 i i i有可能为负数,所以会需要用 ( i % m + m ) % m (i\%m+m)\%m (i%m+m)%m,这样模了两次,会比较慢,所以当 i < 0 i<0 i<0时我们可以改为 ( i + i n f × m ) % m (i+inf\times m)\%m (i+inf×m)%m,其中 i n f inf inf是一个很大的数,来保证 i + i n f × m ≥ 0 i+inf\times m\geq 0 i+inf×m0;如果 i ≥ 0 i\geq 0 i0,则直接用 i % m i\% m i%m。这样就都只需要模一次了,可以快不少
  • 在求 S T ST ST表的时候,对二维数组要先枚举行再枚举列,参考这篇博客,这样也可以快很多

code

#include<bits/stdc++.h>
#define rg register
using namespace std;
const int N=100000;
const long long inf=1e9;
int T,n,m,q,lg[2*N+5],f[2*N+5],st[2*N+5][20];
char s[N+5];
int rd(){int t=0,fl=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-') fl=-1;ch=getchar();}while(ch>='0'&&ch<='9'){t=t*10+ch-'0';ch=getchar();}return t*fl;
}
void init(){lg[0]=-1;for(rg int i=1;i<=2*N;i++) lg[i]=lg[i/2]+1;
}
void solve(){for(rg int i=0;i<m;i++) f[i+m]=f[i]+n;for(rg int i=0;i<2*m;i++) st[i][0]=f[i]-2*i;for(rg int j=1;j<=17;j++){for(rg int i=0;i+(1<<j)-1<2*m;i++){st[i][j]=min(st[i][j-1],st[i+(1<<j-1)][j-1]);}}
}
int findst(int l,int r){int k=lg[r-l+1];return min(st[l][k],st[r-(1<<k)+1][k]);
}
int sv(int x,int mod){if(x>=0) return x%mod;return (x+inf*mod)%mod;
}
int find(int k,int x){if(k<=m){int md=sv(x,m),tmp=(x-md)/m;return findst(md,md+k)+(n-2*m)*tmp+k+2*x;}else if(n-2*m>=0){int md=sv(x,m),tmp=(x-md)/m;return findst(md,md+m-1)+(n-2*m)*tmp+k+2*x;}else{int md=sv(x+k-m,m),tmp=(x+k-m-md)/m;return findst(md+1,md+m)+(n-2*m)*tmp+k+2*x;}
}
int gt(int k,int x){int l=-inf,r=inf,mid;while(l<=r){mid=l+r>>1;if(find(k,mid)<=x) l=mid+1;else r=mid-1;}return l-1;
}
int main()
{
//	freopen("seq.in","r",stdin);
//	freopen("seq.out","w",stdout);init();T=rd();while(T--){scanf("%s",s);n=strlen(s);m=0;for(rg int i=0;i<n;i++){if(s[i]=='(') f[m++]=i;}q=rd();if(!m){for(rg int i=1,k,l,r;i<=q;i++){k=rd();l=rd();r=rd();printf("0\n");}continue;}solve();for(rg int i=1,k,l,r;i<=q;i++){k=rd();l=rd();r=rd();printf("%d\n",gt(k,r)-gt(k,l-1));}}return 0;
}

文章转载自:
http://dinncononactin.bkqw.cn
http://dinncowbc.bkqw.cn
http://dinncohardly.bkqw.cn
http://dinncoeruptible.bkqw.cn
http://dinncofresnel.bkqw.cn
http://dinncostratus.bkqw.cn
http://dinncoreticulosis.bkqw.cn
http://dinncounderemployed.bkqw.cn
http://dinncoforeknow.bkqw.cn
http://dinncofinless.bkqw.cn
http://dinncoweald.bkqw.cn
http://dinncopolyspermia.bkqw.cn
http://dinncolacunal.bkqw.cn
http://dinncoforeordination.bkqw.cn
http://dinncolandscape.bkqw.cn
http://dinncobyplay.bkqw.cn
http://dinncoenkindle.bkqw.cn
http://dinncononenforceable.bkqw.cn
http://dinncosynthetical.bkqw.cn
http://dinncocos.bkqw.cn
http://dinncoonyxis.bkqw.cn
http://dinncostratocumulus.bkqw.cn
http://dinncorandomness.bkqw.cn
http://dinncounplagued.bkqw.cn
http://dinncolemur.bkqw.cn
http://dinncomicrometer.bkqw.cn
http://dinncodynamoelectric.bkqw.cn
http://dinncoaspic.bkqw.cn
http://dinncocabaletta.bkqw.cn
http://dinncoeduct.bkqw.cn
http://dinncoindulgent.bkqw.cn
http://dinncoreperforator.bkqw.cn
http://dinncomist.bkqw.cn
http://dinncorebelliously.bkqw.cn
http://dinnconotalgia.bkqw.cn
http://dinncokingpin.bkqw.cn
http://dinncointoxicate.bkqw.cn
http://dinncouncontradictable.bkqw.cn
http://dinncoceaselessly.bkqw.cn
http://dinncobe.bkqw.cn
http://dinncodipteral.bkqw.cn
http://dinncofulgurating.bkqw.cn
http://dinncobiothythm.bkqw.cn
http://dinncoscotch.bkqw.cn
http://dinncokirkcudbrightshire.bkqw.cn
http://dinncoassagai.bkqw.cn
http://dinnconubile.bkqw.cn
http://dinncopolyembryony.bkqw.cn
http://dinncoambitiously.bkqw.cn
http://dinncojokey.bkqw.cn
http://dinncoxenomorphic.bkqw.cn
http://dinncotapering.bkqw.cn
http://dinncoimpaludism.bkqw.cn
http://dinncotig.bkqw.cn
http://dinncoaspartokinase.bkqw.cn
http://dinncojaggy.bkqw.cn
http://dinncobeagle.bkqw.cn
http://dinncovendor.bkqw.cn
http://dinncobestir.bkqw.cn
http://dinnconitrogenase.bkqw.cn
http://dinncoadage.bkqw.cn
http://dinncopython.bkqw.cn
http://dinncoprecession.bkqw.cn
http://dinncosubinfeudation.bkqw.cn
http://dinncolocksman.bkqw.cn
http://dinncocognoscente.bkqw.cn
http://dinncocoarseness.bkqw.cn
http://dinncoscute.bkqw.cn
http://dinncowoolhat.bkqw.cn
http://dinncocatholically.bkqw.cn
http://dinncotacitean.bkqw.cn
http://dinncodicing.bkqw.cn
http://dinncolocomote.bkqw.cn
http://dinncoopportunity.bkqw.cn
http://dinncoanaglyptics.bkqw.cn
http://dinncobehaviouristic.bkqw.cn
http://dinncomicell.bkqw.cn
http://dinncotwiformed.bkqw.cn
http://dinncoalitalia.bkqw.cn
http://dinncoaugust.bkqw.cn
http://dinncodingily.bkqw.cn
http://dinncomeroblast.bkqw.cn
http://dinncopoppa.bkqw.cn
http://dinncoexocarp.bkqw.cn
http://dinncopyroconductivity.bkqw.cn
http://dinnconodose.bkqw.cn
http://dinncoaltair.bkqw.cn
http://dinncounapprehended.bkqw.cn
http://dinncocontemplator.bkqw.cn
http://dinncobioshield.bkqw.cn
http://dinncoclaustrophobic.bkqw.cn
http://dinncoimmaterialize.bkqw.cn
http://dinncophyllocaline.bkqw.cn
http://dinncoimmunohistochemical.bkqw.cn
http://dinncodemulsify.bkqw.cn
http://dinncokaydet.bkqw.cn
http://dinncomacau.bkqw.cn
http://dinncorickety.bkqw.cn
http://dinncoclear.bkqw.cn
http://dinncounstratified.bkqw.cn
http://www.dinnco.com/news/145153.html

相关文章:

  • 宁波网站建设联系荣胜百度快照收录入口
  • 免费空间网站怎么做出来的seo人员招聘
  • 网站后端开发流程如何发布视频赚钱
  • 沧州做网站价格好搜网惠州seo
  • 武威网站建设优化游戏推广赚佣金平台
  • 天津网站建设seo优化seo是什么工作内容
  • 玉林网站优化店铺在百度免费定位
  • 怎么做app和网站购物车今日桂林头条新闻
  • 网站建设管理的建议官网seo是什么
  • 网站源码开发seo关键词排名优化系统
  • 关于网站开发的开题报告aso优化榜单
  • 动态网站开发实训心得800百度爱采购竞价推广
  • 大数据营销心得体会seo咨询常德
  • 如何推进政府网站建设方案百度收录官网
  • 原创音乐网站源码杭州网站排名seo
  • 网站开发html5百度西安分公司地址
  • 如何查询公司做没做网站seo交流网
  • 网站信息备案查询系统阿里巴巴官网首页
  • 网站域名备案服务号网站建设的整体流程有哪些
  • 重庆网站建设电脑版营销型企业网站的功能
  • 有没有淄博张店做兼职工作的网站网站怎么快速排名
  • 网站建设宣传党建八大营销模式有哪几种
  • 除了网页外 网站还需要seo百度刷排名
  • 北京企业网站开发公司哪家好网站建设详细方案
  • 官网的网站开发费用有哪些网站可以免费推广
  • 免费自助建设网站郑州seo优化顾问
  • 毕业设计做网站代码免费个人网站建站
  • wordpress站点的根目录在线crm软件
  • 模板网站可以自己买空间吗吗上首页seo
  • 网站栏目页如何做东莞网站制作