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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

牛客多校3 - Sort the Strings Revision(笛卡尔树+分治)

發布時間:2024/4/11 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 牛客多校3 - Sort the Strings Revision(笛卡尔树+分治) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目鏈接:點擊查看

題目大意:給出一個長度為 n 的數字串 s[ 0 ],每個位置的賦值初始時為 s[ i ] = i % 10 ( i ∈ [ 0 , n - 1 ] ),現在有一個長度為 n 的排列 p,和一個長度為 n 的數列 d ,相當于 n 次操作,每次操作需要將第 p[ i ] 個位置的數字變為 d[ i ] ,這樣一共能得到 n + 1 個數字串,需要給這 n + 1 個數字按照字典序排序

題目分析:顯然是不能構造出 n + 1 個串然后排序的,而且數據范圍也限制了只能 O( n ) 實現,帶個 log 都有可能 T 飛

因為 n 次操作對于每個位置有且僅有一次替換,而且在字典序的排序中,顯然在原數列中位置更靠前的替換的影響要大于位置較靠后的替換,這樣我們可以分治去做:假設當前分治的排列區間是 [ l , r ],設 pos 為 p[ l ] ~ p[ r ] 中的最小值

  • p[ pos ] % 10 > d[ pos ],替換后數列會變得更小,s[ 0 ] ~ s[ pos ] 的字典序要大于 s[ pos + 1 ] ~ s[ n ] 的字典序
  • p[ pos ] % 10 < d[ pos ],替換后數列會變得更大,s[ 0 ] ~ s[ pos ] 的字典序要小于 s[ pos + 1 ] ~ s[ n ] 的字典序
  • p[ pos?] % 10 == d[ pos ],替換后數列不變
  • 現在的問題是,如何 O( n ) 求出每個區間的最小值呢?可以用笛卡爾樹,無腦跑出笛卡爾樹后,就可以dfs遍歷每個節點所能覆蓋的區間了

    我寫的笛卡爾樹一般喜歡加個哨兵節點當做 root,所以在 dfs 的時候需要特判一下,防止死循環

    代碼:
    ?

    #include<iostream> #include<cstdio> #include<string> #include<ctime> #include<cmath> #include<cstring> #include<algorithm> #include<stack> #include<climits> #include<queue> #include<map> #include<set> #include<sstream> #include<cassert> #include<bitset> using namespace std;typedef long long LL;typedef unsigned long long ull;const int inf=0x3f3f3f3f;const int N=2e6+100;const int mod=1000000007;const int Hash=10000019;struct Node {int l,r; }tree[N];int p[N],d[N],rk[N],root=N-1,num;stack<int>st;void build(int n) {for(int i=0;i<n;i++){while(st.size()&&p[st.top()]>p[i])st.pop();tree[i].l=tree[st.top()].r;tree[st.top()].r=i;st.push(i);} }void dfs(int k,int l,int r) {if(k==root){if(tree[k].l)dfs(tree[k].l,l,r);elsedfs(tree[k].r,l,r);return;}if(l>r)return;if(l==r){rk[l]=num++;return;}if(p[k]==inf){for(int i=l;i<=r;i++)rk[i]=num++;return;}if(p[k]%10<d[k])dfs(tree[k].l,l,k),dfs(tree[k].r,k+1,r);elsedfs(tree[k].r,k+1,r),dfs(tree[k].l,l,k); }void init(int n) {num=0;for(int i=0;i<=n;i++)tree[i].l=tree[i].r=0;tree[root].l=tree[root].r=0;p[root]=-inf;while(st.size())st.pop();st.push(root); }int main() { #ifndef ONLINE_JUDGE // freopen("data.in.txt","r",stdin); // freopen("data.out.txt","w",stdout); #endif // ios::sync_with_stdio(false);int w;cin>>w;while(w--){int n;scanf("%d",&n);init(n);LL pseed,pa,pb,pmod,dseed,da,db,dmod;scanf("%lld%lld%lld%lld%lld%lld%lld%lld",&pseed,&pa,&pb,&pmod,&dseed,&da,&db,&dmod);for(int i=0;i<n;i++){p[i]=i;d[i]=dseed%10;dseed=(dseed*da+db)%dmod;}for(int i=1;i<n;i++){swap(p[pseed%(i+1)],p[i]);pseed=(pseed*pa+pb)%pmod;}for(int i=0;i<n;i++)if(p[i]%10==d[i])//改變第i個位置沒有效果 p[i]=inf;build(n);dfs(root,0,n);LL ans=0,base=1;for(int i=0;i<=n;i++){ans=(ans+base*rk[i])%mod;base=base*Hash%mod;}printf("%lld\n",ans);}return 0; }

    ?

    總結

    以上是生活随笔為你收集整理的牛客多校3 - Sort the Strings Revision(笛卡尔树+分治)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    主站蜘蛛池模板: 亚洲成人乱码 | 欧美日韩大片在线观看 | 国产高潮国产高潮久久久 | 熟女人妻一区二区三区免费看 | 激情偷乱人成视频在线观看 | 久草国产在线视频 | 成年视频在线观看 | 亚洲区国产区 | 对白超刺激精彩粗话av | 亚洲AV无码精品色毛片浪潮 | 亚洲中文字幕一区在线 | 嫩草研究院在线 | 高清一区二区三区视频 | 97视频免费看| 天天射寡妇射 | 亚洲毛茸茸 | 国产手机精品视频 | 成人在线观看小视频 | 欧美毛茸茸 | 亚洲婷婷在线观看 | 日本在线不卡一区二区三区 | 国产乱国产乱老熟300部视频 | 污污内射久久一区二区欧美日韩 | 亚洲福利影院 | 成人免费在线视频 | 日本一区二区在线 | 国产日韩欧美高清 | 成人午夜精品 | 91插插影库 | 麻豆蜜桃视频 | 国产成人精品av久久 | 亚洲国产日韩欧美在线观看 | 欧美成人第一页 | 中文字幕资源站 | 在线观看少妇 | 麻豆精品免费观看 | 免费视频黄色 | 久久男人精品 | 狠狠爱夜夜 | 视频一区二区在线播放 | 97色综合| 一区二区高清视频 | 青青草在线免费 | 嫩草嫩草嫩草嫩草 | ass精品国模裸体欣赏pics | 国产美女91 | 精品久久久久一区二区国产 | 精品爆乳一区二区三区 | 欧美xxxx69 | 亚洲国产一区二区a毛片 | 亚洲一区二区三区在线 | 欧美日韩福利视频 | 美女一区二区三区视频 | 国产一级黄色片子 | 打屁股调教视频 | 免费在线观看视频 | 国产suv精品一区二区四 | 69精品视频 | 人人玩人人弄 | 成人香蕉视频 | 国产刺激高潮av | 激情六月天婷婷 | 久久久九九九热 | 中文字幕日产乱码中 | 国产一区久久久 | 日韩毛片在线观看 | 欧美少妇一区二区三区 | 久久色图| 精品人伦一区二区三区蜜桃网站 | 岛国av一区二区三区 | 顶级毛茸茸aaahd极品 | 日韩电影精品 | 韩国一区二区在线观看 | 电影一区二区三区 | 成人国产精品入口免费视频 | 国产aaa| 精品伊人 | 人人妻人人藻人人爽欧美一区 | 日韩欧美精品 | 色综合久久久无码中文字幕波多 | 极品人妻一区二区三区 | 久久视| 国产精品一区二区黑人巨大 | 第一色综合 | 久久99影院 | 无码精品国产一区二区三区 | 精品五月天 | 日韩在线观看网址 | 亚洲成人免费在线 | 国产1区在线观看 | 日本肉体xxxx裸体xxx免费 | 色悠悠久久综合 | 在线观看特色大片免费网站 | 精品视频免费在线观看 | 女生和男生一起插插插 | 香港三级韩国三级日本三级 | 人妻互换 综合 | 秋霞午夜鲁丝一区二区老狼 | 欧美久久激情 |