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

最浪漫的编程代码可复制厦门seo代运营

最浪漫的编程代码可复制,厦门seo代运营,北京有哪些炫酷的网站页面,中山哪家做网站好题意: 给出一个长度为n的字符,字符是前m个小写字母,有q个询问,每次询问一个最短子序列的长度满足不是[l,r]内任意一个子序列 思路: [l,r]中子序列可以看成是从[l,r]中的某个位置开始,跳到下一个字符的位…

题意:

给出一个长度为n的字符,字符是前m个小写字母,有q个询问,每次询问一个最短子序列的长度满足不是[l,r]内任意一个子序列

思路:

[l,r]中子序列可以看成是从[l,r]中的某个位置开始,跳到下一个字符的位置,如果满足位置在r以内就取这个字符,然后继续从这个字符的位置开始跳,子序列的长度就是跳的步数。

那么最小的没出现过的子序列长度就是从l-1开始跳,每次跳到所有字符出现的最大坐标处,如果在r以内就继续跳,超过r就表明当前收集的子串的下一个最远的字符位置超出了r,不属于[l,r]的子串,那么答案就是当前收集的子串长度+1(步数+1)

用nxt[i][j]表示从第i个位置往后的下一个字符为j的坐标,那么我们从后往前处理

用f[i][j]表示从第i个位置开始走,走2^j步能走到的最大坐标,先预处理f[i][0],转换方程是f[i][j]=f[f[i][j-1]][j-1]

然后在询问每个[l,r]的时候,now从l-1开始,j从大到小枚举,如果f[now][j]<r说明可以跳,跳的步数是1<<j,now=f[now][j],最后答案就是步数+1

#include<bits/stdc++.h>
//#define int long long
using namespace std;
const int N=2e5+10;
int n,m,q;
string s;
int nxt[N][30];
int f[N][30];
int pos[30];
void sove(){cin>>m>>n;cin>>s;s=" "+s;for(int i=0;i<m;i++)nxt[n][i]=n+1;for(int i=n;i>=1;i--){pos[s[i]-'a']=i;for(int j=0;j<m;j++){if(pos[j])nxt[i-1][j]=pos[j];else nxt[i-1][j]=n+1;
//			cout<<"i-1=="<<i-1<<" j=="<<j<<" nxt="<<nxt[i-1][j]<<endl;}}for(int i=0;i<=n;i++){int mx=0;for(int j=0;j<m;j++)mx=max(mx,nxt[i][j]);f[i][0]=mx;
//		cout<<"i=="<<i<<" f=="<<f[i][0]<<endl;for(int j=0;j<19;j++) f[n][j]=f[n+1][j]=n+1;}for(int j=1;j<19;j++){for(int i=0;i<=n;i++){f[i][j]=f[f[i][j-1]][j-1];
//			cout<<"i=="<<i<<" j=="<<j<<" f="<<f[i][j]<<endl;}}cin>>q;while(q--){int ans=0;int l,r;cin>>l>>r;int now=l-1;for(int j=18;j>=0;j--){if(f[now][j]<=r){
//				cout<<"now=="<<now<<" j=="<<j<<" f=="<<f[now][j]<<endl;ans+=1<<j;now=f[now][j];}}cout<<ans+1<<endl;}
}
int main(){ios::sync_with_stdio(false);cin.tie(),cout.tie();int t=1;
//	cin>>t;while(t--){sove();}return 0;
}

http://www.pjxw.cn/news/25375.html

相关文章:

  • 湖北省城乡建设厅网站北京网站优化托管
  • php做网站时间代码凡科建站登录
  • 龙华品牌网站制作郑州百度网站优化排名
  • 做网站培训班windows优化大师win10
  • 请问怎么做网站常见的营销方式有哪些
  • 商务网站建设方案ppt微信公众号推广
  • 西安网站建设公司找哪家营销技巧和话术
  • 网站处于建设中会显示什么英文营销培训课程内容
  • 网站速度测试怎么开设自己的网站
  • 有没有那个网站是做点心的信息检索关键词提取方法
  • 北京移动官网网站建设seo求职
  • 界首网站优化公司百度官网电话
  • 制作精美网站建设服务周到信息流推广渠道有哪些
  • 网站翻新后seo怎么做seo描述是什么
  • 河北网站备案管理系统关键词歌词林俊杰
  • 海口今日头条新闻深圳百度seo代理
  • 怎样在商务部网站做备案免费发帖推广平台
  • 美食网站联系我们怎么做网页推广链接怎么做
  • 上海网站建设shwzzzapp排名优化
  • 开发公司大厅售后优化手机流畅度的软件
  • 汕头做网站优化哪家好运营推广计划
  • 视频变成网站怎么做的优化设计单元测试卷
  • 黑龙江两学一做网站关键词排名优化软件价格
  • 商业网站建设产品推广的渠道
  • 郑州公司做网站关键词优化顾问
  • wordpress www杭州seo公司排名
  • 找人做网站排名优化win11优化大师
  • 公司建设网站的申请信用卡下拉关键词排名
  • 宁波中科网站建设有限公司公司网站制作公司
  • 58同城的网站建设百度关键词收录