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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

BZOJ 1031: [JSOI2007]字符加密Cipher( 后缀数组 )

發布時間:2025/3/15 javascript 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BZOJ 1031: [JSOI2007]字符加密Cipher( 后缀数组 ) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

為什么我的后綴數組跑得這么慢...

把字符串復制一遍放在最后, 然后跑sa, 掃一遍就行了...?

---------------------------------------------------------------------

#include<bits/stdc++.h>using namespace std;const int maxn = 200009;struct HASH {int id[maxn], N;HASH() {N = 0;}inline void add(int v) {id[N++] = v;}inline void work(){sort(id, id + N);N = unique(id, id + N) - id;}inline int hash(int c) {return lower_bound(id, id + N, c) - id;}inline int _hash(int c) {return id[c];}} h;int sa[maxn], rank[maxn], height[maxn], cnt[maxn], N;char S[maxn];void build_sa() {int m = h.N, *x = height, *y = rank;for(int i = 0; i < m; i++) cnt[i] = 0;for(int i = 0; i < N; i++) cnt[x[i] = S[i]]++;for(int i = 1; i < m; i++) cnt[i] += cnt[i - 1];for(int i = N - 1; ~i; i--) sa[--cnt[x[i]]] = i;for(int k = 1; k <= N; k <<= 1) {int p = 0;for(int i = N - k; i < N; i++) y[p++] = i;for(int i = 0; i < N; i++) if(sa[i] >= k) y[p++] = sa[i] - k;for(int i = 0; i < m; i++) cnt[i] = 0;for(int i = 0; i < N; i++) cnt[x[y[i]]]++;for(int i = 1; i < N; i++) cnt[i] += cnt[i - 1];for(int i = N - 1; ~i; i--) sa[--cnt[x[y[i]]]] = y[i];swap(x, y); x[sa[0]] = 0; p = 1;for(int i = 1; i < N; i++) ? ?x[sa[i]] = y[sa[i]] == y[sa[i - 1]] && y[sa[i] + k] == y[sa[i - 1] + k] ? p - 1 : p++;if(p >= N) break;m = p;}}int main() {scanf("%s", S);N = strlen(S);for(int i = 0; i < N; i++) ? ?h.add(S[i + N] = S[i]);N <<= 1;h.add(S[N++] = -1);h.work();for(int i = 0; i < N; i++) ? ?S[i] = h.hash(S[i]);build_sa();for(int i = 0; i < N; i++) if(sa[i] < N / 2) ? ?putchar(h._hash(S[sa[i] + N / 2 - 1]));return 0;}

---------------------------------------------------------------------?

1031: [JSOI2007]字符加密Cipher

Time Limit:?10 Sec??Memory Limit:?162 MB
Submit:?4199??Solved:?1704
[Submit][Status][Discuss]

Description

喜歡鉆研問題的JS 同學,最近又迷上了對加密方法的思考。一天,他突然想出了一種他認為是終極的加密辦法:把需要加密的信息排成一圈,顯然,它們有很多種不同的讀法。例如下圖,可以讀作:

?

JSOI07 SOI07J OI07JS I07JSO 07JSOI 7JSOI0 把它們按照字符串的大小排序: 07JSOI 7JSOI0 I07JSO JSOI07 OI07JS SOI07J 讀出最后一列字符:I0O7SJ,就是加密后的字符串(其實這個加密手段實在很容易破解,鑒于這是突然想出來的,那就^^)。但是,如果想加密的字符串實在太長,你能寫一個程序完成這個任務嗎?

Input

輸入文件包含一行,欲加密的字符串。注意字符串的內容不一定是字母、數字,也可以是符號等。

Output

輸出一行,為加密后的字符串。

Sample Input

JSOI07

Sample Output

I0O7SJ

HINT

對于100%的數據字符串的長度不超過100000。

Source

?

轉載于:https://www.cnblogs.com/JSZX11556/p/4713068.html

總結

以上是生活随笔為你收集整理的BZOJ 1031: [JSOI2007]字符加密Cipher( 后缀数组 )的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 国产三区四区视频 | 日本黄色激情视频 | 亚洲免费高清 | 欧美freesex黑人又粗又大 | 狠狠爱天天干 | 欧美一级欧美三级在线观看 | 欧美日韩激情网 | 91亚洲专区| 18岁免费观看电视连续剧 | 国产视频久久久久 | 天天爽夜夜爽夜夜爽精品 | 日韩av在线网 | 欧美综合第一页 | 精品人妻互换一区二区三区 | 国精产品一区一区三区有限公司杨 | 夜夜夜网站 | 成人激情片 | 精品国产乱码一区二区三 | 一区二区三区四区五区在线视频 | 三级大片在线观看 | 激情影院内射美女 | 人人上人人干 | 性欧美一级 | 国产成人无码一区二区在线播放 | 可以看黄色的网站 | 黄色av网站在线播放 | 在线观看日韩视频 | 国产高潮在线 | 爱情岛论坛亚洲自拍 | 我和岳m愉情xxxⅹ视频 | 99爱免费 | 亚洲午夜精品久久久久久app | 捆绑调教sm束缚网站 | 1000部啪啪未满十八勿入 | 无遮挡边吃摸边吃奶边做 | 成人毛片av | 亚洲一区h | 国自产拍偷拍精品啪啪一区二区 | 在线麻豆 | 波多野结衣精品在线 | 国产网站免费在线观看 | 麻豆tv在线观看 | 91大神网址 | 亚洲免费一 | 夜夜骑狠狠干 | 一级v片 | 少妇色 | 精品国产www | 91麻豆免费视频 | 日韩精品999| 色小说在线 | 欧美色一区二区三区在线观看 | 欧美日一本 | 欧美裸体xxx | 午夜看毛片 | 中文字幕999 | 日韩国产片 | 在线视频精品免费 | 国产欧美日韩精品一区二区三区 | 女同在线视频 | 日韩精品成人av | 亚洲第一色视频 | 五月婷婷七月丁香 | 精品中文字幕一区二区三区 | 欧美一区二区三区黄片 | 香蕉在线视频播放 | 欧美在线观看一区二区三区 | 日本阿v视频 | 国产精品96| 欧美日韩一区精品 | 三级免费观看 | 国产成人在线免费视频 | 国产精品无码午夜福利 | 国产在线观看网站 | 天天鲁一鲁摸一摸爽一爽 | 色老头一区二区三区 | 午夜噜噜| 久久久999国产 | 边吃奶边添下面好爽 | 在线免费观看污视频 | 久久综合狠狠综合久久综合88 | 无码少妇一区二区三区 | 99久久99久久精品国产片 | 精品国产影院 | 色天使在线视频 | brazzers欧美一区二区 | 国产一卡二卡三卡 | 污污在线看 | 国产小视频免费在线观看 | 日穴视频| 中文字幕在线播放av | 开心激情五月婷婷 | 在线免费观看av网址 | 亚洲无吗一区二区三区 | 国产一线二线三线女 | 中文字幕巨乳 | 一级黄色性生活片 | www.男人天堂.com| 欧美成人专区 |