日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P3975-[TJOI2015]弦论【SAM】

發布時間:2023/12/3 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 P3975-[TJOI2015]弦论【SAM】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

正題

題目鏈接:https://www.luogu.com.cn/problem/P3975


題目大意

給一個字符串ssst,kt,kt,k。求字符串ssskkk大的子串。

  • T=0T=0T=0時,相同的子串算一個
  • T=1T=1T=1時,不同位置的相同子串算不同的串

  • 解題思路

    T=0T=0T=0時很簡單,對于每個位置求該位置開始能到多少個串即可,也就是fx=∑x?>y(fy+1)f_x=\sum_{x->y}(f_y+1)fx?=x?>y?(fy?+1)然后根據fxf_xfx?像權值線段樹那樣走就好了

    T=1T=1T=1時,我們需要求出每個endposendposendpos的大小,因為對于走到該節點的一個子串,顯然在該位置的endposendposendpos的集合為結尾也有一個一樣的子串,因為每個endposendposendpos包含所有的子節點的endposendposendpos,所以我們對于一個原串的后綴讓siz+1siz+1siz+1,之后讓每個節點加上它parentsparentsparents樹上節點的sizsizsiz就好。

    用桶排就可以做到O(n)O(n)O(n)


    codecodecode

    #include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int N=1e6+1; int n,las,cnt,k,t,c[N],fa[N],sum[N]; int siz[N],ch[N][26],a[N],len[N]; char s[N]; void add(int c){int p=las;int np=las=++cnt;len[np]=len[p]+1;siz[cnt]++;for(;p&&!ch[p][c];p=fa[p])ch[p][c]=np;if(!p)fa[np]=1;else{int q=ch[p][c];if(len[p]+1==len[q])fa[np]=q;else{int nq=++cnt;len[nq]=len[p]+1;memcpy(ch[nq],ch[q],sizeof(ch[nq]));fa[nq]=fa[q];fa[np]=fa[q]=nq;for(;p&&ch[p][c]==q;p=fa[p])ch[p][c]=nq;}}return; } void solve(int x,int k){if(k<=siz[x])return;k-=siz[x];for(int i=0;i<26;i++){if(!ch[x][i])continue;if(k>sum[ch[x][i]])k-=sum[ch[x][i]];else {printf("%c",i+'a');solve(ch[x][i],k);return;}}return; } int main() {cnt=las=1;scanf("%s",s+1);n=strlen(s+1);for(int i=1;i<=n;i++)add(s[i]-'a');scanf("%d%d",&t,&k);for(int i=1;i<=cnt;i++)c[len[i]]++;for(int i=1;i<=n;i++)c[i]+=c[i-1];for(int i=1;i<=cnt;i++)a[c[len[i]]--]=i;for(int i=cnt;i>=1;i--)siz[fa[a[i]]]+=siz[a[i]];for(int i=1;i<=cnt;i++)t?(sum[i]=siz[i]):(sum[i]=siz[i]=1);siz[1]=siz[0]=sum[1]=sum[0]=0;for(int i=cnt;i>=1;i--)for(int j=0;j<26;j++)if(ch[a[i]][j])sum[a[i]]+=sum[ch[a[i]][j]]; if(sum[1]<k)printf("-1");else solve(1,k);return 0; }

    總結

    以上是生活随笔為你收集整理的P3975-[TJOI2015]弦论【SAM】的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 午夜精品久久久久久久99黑人 | av女星全部名单 | 黄片毛片在线观看 | 国产私人影院 | 99久久成人| brazzers精品成人一区 | av波多野吉衣 | 亚洲啪啪 | 久久中文网 | 中文字幕+乱码+中文字幕明步 | 日本毛片网站 | 精品国模一区二区三区欧美 | 日日夜夜狠 | 精品视频一区在线观看 | jizz日本18| 国产乡下妇女做爰毛片 | av噜噜在线 | 91亚色视频 | 成品人视频ww入口 | 性av网站 | 91啪国产 | 国产一区二区影院 | 亚洲成人999 | aaaaa毛片| av电影在线观看不卡 | 色爱av | 欧美日韩一二三区 | 色一情一伦一子一伦一区 | 国产精品--色哟哟 | 午夜国产 | 日本少妇aaa| 国产一区二区精品在线观看 | 性xxxx视频| 娇小萝被两个黑人用半米长 | 800av在线视频 | 2018天天弄| 青青青av| 国产一级特黄毛片 | 亚洲毛片在线看 | 正在播放一区 | 欧美热热 | 91在线网站 | 久久一道本 | 茄子爱啪啪 | 久久精品中文字幕 | 亚洲免费久久 | 日韩精品中文字幕一区二区 | 波多野结衣小视频 | 小箩莉末发育娇小性色xxxx | 秋霞欧美视频 | a级黄色片免费看 | 日本一级三级三级三级 | 欧美特黄一级视频 | 欧美色久 | 清清草免费视频 | 欧美亚洲一区二区在线观看 | 免费裸体视频女性 | 亚洲一区精品视频在线观看 | 成年丰满熟妇午夜免费视频 | 亚洲日本国产 | 国产日韩精品一区二区三区在线 | 永久免费,视频 | 锕锕锕锕锕锕锕锕 | 欧美在线xxxx | 青草一区二区 | 69精品在线观看 | 中国一级黄色 | 免费av一级| 福利国产视频 | 极品美妇后花庭翘臀娇吟小说 | 午夜爽视频 | 亚洲精品乱码久久久久久自慰 | 亚洲国产果冻传媒av在线观看 | 少妇一级淫片日本 | 欧美在线不卡 | 自由 日本语 热 亚洲人 | 免费观看一区二区三区视频 | 成人美女免费网站视频 | 69久人妻无码精品一区 | 久草视频在线资源站 | 成人在线免费视频观看 | 艳妇臀荡乳欲伦交换在线播放 | 国产一级片a | 中文字幕免费高清在线观看 | 久久免费在线观看 | 无码国内精品人妻少妇蜜桃视频 | www中文字幕在线观看 | 中文字幕第九页 | 国产一区二区三区视频在线观看 | 国产精品午夜福利 | 日韩欧美色图 | 日韩视频在线播放 | 一区二区免费av | 第一av在线| h片大全 | 亚洲第一页在线 | 日韩一区二区三区免费视频 | 91精东传媒理伦片在线观看 | 成人黄页网站 |