青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

coreBugZJ

此 blog 已棄。

AC's code , FZU 2011年3月月賽之 C, FZU 2012

Problem 2012 AC's code

Time Limit: 1000 mSec    Memory Limit : 32768 KB

Problem Description

AC is given two strings A and B, and then he wants to insert B into A. As we know, there are |A| + 1 possible ways to make the final string! For example, if A = “orz” and B = “p”, then AC may get four final strings: “porz”, “oprz”, “orpz”, “orzp”. However, these strings are not so beautiful, so AC sort them in lexicographic order, then he gets {“oprz”, “orpz”, “orzp”,”porz”}.

Now AC wants to know the k-th string in the sorted strings! For example, if AC wants to know the first string in the sorted strings, the answer is “oprz”, the second is “orpz”, the third is “orzp”, and the 4-th is “porz”.

Now you are given string A and B, and the number K, in this problem, AC guarantees that K is valid.

Input

The first line of the input data is an integer number T (T <= 1000), represent the number of test cases.

For each case, three lines follow.

The first line has one string indicates A. (Without any space in A)

The second line has one string indicates B. (Without any space in B)

The third line has one integer indicates K.

(1 <= |A|, |B| <= 10000, 1 <= K <= |A| + 1)

Output

For each test case, output a single line “Case idx:” where idx is the test case number starts from 1. Then one line output the k-th string in the sorted string.

Sample Input

4
orz
p
1
orz
p
2
orz
p
3
orz
p
4

Sample Output

Case 1:
oprz
Case 2:
orpz
Case 3:
orzp
Case 4:
porz



分析:
字符串 hash,求第 k 小元素。

字符串hash 函數為
hash ( s[ 0..n ] ) = ( s[0]*q^n + s[1]*q^(n-1) + ...... + s[n-1]*q^1 + s[n]*q^0 ) mod p,其中,p, q 為大質數,
適當預處理(見函數init )后,B 插入在 A 中任意位置所形成的字符串的任意前綴的hash 值都能 O(1) 計算出來(見函數hash)。

求第 k 小元素可以使用修改的快速排序(見函數sort),其中要注意使用隨機,否則超時。復雜度 O(n)。

比較兩個字符串大小時,只比較它們的最長公共前綴的后一個字符(見函數 cmp)。
而最長公共前綴通過二分其長度,用hash值判斷是否相等,可以O(log(|A|+|B|) )得到(見函數 cmp)。

另一種做法是用后綴數組的。


我的代碼:
  1#include <stdio.h>
  2#include <string.h>
  3#include <stdlib.h>
  4#include <time.h>
  5
  6typedef  long long  Lint;
  7
  8#define  PRIME  55566677
  9#define  HH     23456789
 10
 11#define  L  21009
 12
 13int la, lb, k;
 14char a[ L ], b[ L ], c[ L + L ];
 15Lint ha[ L ], hb[ L ], hh[ L ];
 16
 17void init() {
 18        int i;
 19        srand( time( 0 ) );
 20
 21        memset( ha, 0sizeof(ha) );
 22        ha[ 0 ] = a[ 0 ] % PRIME;
 23        for ( i = 1; a[ i ]; ++i ) {
 24                ha[ i ] = ( ha[ i - 1 ] * HH + a[ i ] ) % PRIME;
 25        }

 26        la = i;
 27
 28        memset( hb, 0sizeof(hb) );
 29        hb[ 0 ] = b[ 0 ] % PRIME;
 30        for ( i = 1; b[ i ]; ++i ) {
 31                hb[ i ] = ( hb[ i - 1 ] * HH + b[ i ] ) % PRIME;
 32        }

 33        lb = i;
 34
 35        hh[ 0 ] = 1;
 36        for ( i = 1; i < L; ++i ) {
 37                hh[ i ] = ( hh[ i -1 ] * HH ) % PRIME;
 38        }

 39}

 40
 41/*
 42insert b after a[ i ]
 43query hash of [0..j]
 44*/

 45Lint hash( int i, int j ) {
 46        if ( i < 0 ) {
 47                if ( j < lb ) {
 48                        return hb[ j ];
 49                }

 50                return ( hb[ lb-1 ] * hh[ j-lb+1 ] + ha[ j-lb ] ) % PRIME;
 51        }

 52        if ( j <= i ) {
 53                return ha[ j ];
 54        }

 55        if ( j <= i + lb ) {
 56                return ( ha[ i ] * hh[ j-i ] + hb[ j-i-1 ] ) % PRIME;
 57        }

 58        return ( ha[i]*hh[j-i] + hb[lb-1]*hh[j-i-lb] + (ha[j-lb]+PRIME-((ha[i]*hh[j-lb-i])%PRIME)) ) % PRIME;
 59}

 60
 61char getint i, int j ) {
 62        if ( i < 0 ) {
 63                if ( j < lb ) {
 64                        return b[ j ];
 65                }

 66                return a[ j-lb ];
 67        }

 68        if ( j <= i ) {
 69                return a[ j ];
 70        }

 71        if ( j <= i + lb ) {
 72                return b[ j-i-1 ];
 73        }

 74        return a[ j-lb ];
 75}

 76
 77int cmp( int i, int j ) {
 78        int low = 0, high = la+lb-1, mid, lcp=-1;
 79        while ( low <= high ) {
 80                mid = ( low + high ) / 2;
 81                if ( hash(i,mid)==hash(j,mid) ) {
 82                        low = mid + 1;
 83                        if ( lcp < mid ) {
 84                                lcp = mid;
 85                        }

 86                }

 87                else {
 88                        high = mid - 1;
 89                }

 90        }

 91        return get(i,lcp+1- get(j,lcp+1);
 92}

 93
 94int idx[ L ];
 95void sort( int le, int ri, int k ) {
 96        int i, j, x;
 97        if ( (le>=ri) || (k<1) ) {
 98                return;
 99        }

100        i = le + ( rand() % ( ri - le + 1 ) );
101        x = idx[ i ];
102        idx[ i ] = idx[ le ];
103        idx[ le ] = x;
104        i = le;
105        j = ri;
106        while ( i < j ) {
107                while ( (i<j) && (cmp(x,idx[j])<=0) ) {
108                        --j;
109                }

110                if ( i < j ) {
111                        idx[ i++ ] = idx[ j ];
112                }

113                while ( (i<j) && (cmp(idx[i],x)<=0) ) {
114                        ++i;
115                }

116                if ( i < j ) {
117                        idx[ j-- ] = idx[ i ];
118                }

119        }

120        idx[ i ] = x;
121        if ( i - le + 1 < k ) {
122                sort( i+1, ri, k-(i-le+1) );
123        }

124        else if ( i - le + 1 > k ) {
125                sort( le, i-1, k );
126        }

127}

128
129char* solve() {
130        int i, p;
131        char tmp;
132        for ( i = 0; i <= la; ++i ) {
133                idx[ i ] = i - 1;
134        }

135        sort( 0, la, k );
136        c[ 0 ] = 0;
137        p = idx[ k - 1 ];
138        tmp = a[ p + 1 ];
139        a[ p + 1 ] = 0;
140        strcat( c, a );
141        a[ p + 1 ] = tmp;
142        strcat( c, b );
143        strcat( c, a+p+1 );
144        return (char*)c;
145}

146
147int main() {
148        int td, cd = 0;
149        scanf( "%d"&td );
150        while ( td-- > 0 ) {
151                scanf( "%s%s%d", a, b, &k );
152                init();
153                printf( "Case %d:\n%s\n"++cd, solve() );
154        }

155        return 0;
156}

157


posted on 2011-03-21 21:12 coreBugZJ 閱讀(1912) 評論(9)  編輯 收藏 引用 所屬分類: ACM

Feedback

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-22 18:30 sodaisinie

代碼無法打開啊  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-22 18:52 coreBugZJ

@sodaisinie
原來是在ubuntu下用firefox編輯的。。。
已經win7下用IE重新編輯了  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-22 21:17 sodaisinie

贊@coreBugZJ
  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-23 16:26 maoyu

你好,請為什么這樣的hash就可以保證沒有重復值呢?萬一出現兩種添加方式經過hash后的值一樣,怎么辦呢?  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-23 19:48 maoyu

還有一個疑問,這里用到的是大素數modP,我之前開了一個5位數的大素數,就WA了,然后把素數換成你的那兩個,就AC了。那到底要多大呢?  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-23 20:51 coreBugZJ

@maoyu
這個字符串 hash 從大空間映射到小空間,是有可能出現沖突的,只是輸入空間雖大,需要區別的數據量不是很大,沖突的概率還是比較小的,素數開的大一些,降低沖突的概率。。。
PS:這是我第一次寫字符串 hash,以前字典樹Trie用的比較多(對大量長字符串沒轍 ^_^ )  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-24 17:45 maoyu

我看福大核武的題解,也是這么說。只是我個人覺得這題如果數據BT,需要兩個不同的狀態其hash值一定不同,我們能證明這種hash方法產生的每個狀態hash值都不一樣嗎?  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-24 17:56 coreBugZJ

@maoyu
我不能證明,比賽時我們就是卡在這一題和最后一題上,我是看了福大核武的題解過的。。。  回復  更多評論   

# re: AC's code , FZU 2011年3月月賽之 C, FZU 2012 2011-03-26 17:30 Dragon521

真的很贊  回復  更多評論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一本一本久久a久久精品综合妖精| 国产精品vvv| 99精品欧美一区| 亚洲免费观看高清完整版在线观看熊 | 久久国产视频网| 校园春色综合网| 狠狠色狠狠色综合日日tαg | 亚洲国产欧美在线人成| 夜色激情一区二区| 国产精品亚洲精品| 久久综合亚洲社区| 欧美电影免费观看| 亚洲一区二区三区精品在线观看| 亚洲欧美中文日韩v在线观看| 精品91在线| 亚洲精品一区久久久久久| 国产精品乱码一区二区三区 | 欧美国产精品劲爆| 欧美日韩在线播放三区四区| 性欧美video另类hd性玩具| 久久国产欧美| 亚洲精品自在在线观看| 亚洲网站在线播放| 在线国产亚洲欧美| 亚洲美女av在线播放| 国产欧美日韩在线视频| 美女日韩欧美| 欧美婷婷六月丁香综合色| 久久久www免费人成黑人精品| 欧美成人一区二区三区片免费| 亚洲欧美日韩另类精品一区二区三区| 午夜精品久久久久久久蜜桃app | 亚洲美女中出| 亚洲欧美成人精品| 亚洲欧洲精品一区| 亚洲欧美日韩天堂| 亚洲精品国精品久久99热| 亚洲永久免费| 91久久精品国产91性色| 一区二区成人精品| 亚洲第一网站免费视频| 亚洲视频碰碰| 最新国产成人在线观看| 香蕉久久一区二区不卡无毒影院| 亚洲黄色一区| 亚洲欧美在线另类| 99re热这里只有精品视频| 欧美亚洲一区二区三区| 一区二区三欧美| 久久免费国产精品| 伊人色综合久久天天| 一区二区三区你懂的| 影音先锋中文字幕一区二区| 日韩视频精品| 国产精品免费区二区三区观看| 亚洲一区二区在线看| 久久这里有精品视频| 小黄鸭视频精品导航| 欧美国产亚洲另类动漫| 久久久国产午夜精品| 国产精品成人在线| 欧美激情欧美激情在线五月| 国产一级揄自揄精品视频| 99精品热6080yy久久| 最新日韩av| 久久久国产一区二区| 欧美亚洲三级| 欧美日韩在线免费视频| 亚洲第一区在线| 国产综合色产在线精品| 亚洲一区二区三区免费观看| 一区二区三区日韩欧美精品| 免费久久99精品国产| 久久免费视频这里只有精品| 欧美日韩免费在线观看| 亚洲国产另类久久精品| 在线精品高清中文字幕| 欧美一区二区视频网站| 羞羞答答国产精品www一本 | 欧美成人中文字幕| 国内精品一区二区三区| 亚洲欧美日本伦理| 亚洲欧美精品| 欧美伦理在线观看| 亚洲国产精品久久久| 在线观看av一区| 久久精品免费观看| 久久久久久久高潮| 国产婷婷97碰碰久久人人蜜臀| 亚洲淫片在线视频| 亚洲欧美日韩国产综合| 欧美视频精品在线| 夜夜爽www精品| 在线视频亚洲欧美| 欧美国产日韩一二三区| 欧美电影免费观看| 亚洲国内精品| 免费欧美日韩| 欧美激情在线播放| 亚洲精品一区二区三区樱花| 免费日韩成人| 亚洲国产美女久久久久| 91久久中文字幕| 欧美电影在线播放| 最新精品在线| 亚洲视频1区2区| 欧美性视频网站| 亚洲一区二区在线观看视频| 亚洲欧美不卡| 国产精品一区二区久激情瑜伽| 亚洲中无吗在线| 久久精品亚洲| 一区二区三区在线不卡| 久久视频一区| 亚洲成人资源网| 亚洲精品中文字幕女同| 欧美日本亚洲| 在线一区二区三区四区五区| 亚洲摸下面视频| 国产嫩草一区二区三区在线观看| 亚洲欧美亚洲| 久久综合亚洲社区| 亚洲国产精品第一区二区| 欧美成人黑人xx视频免费观看| 亚洲欧洲精品一区二区精品久久久| 夜夜精品视频一区二区| 欧美性大战xxxxx久久久| 亚洲欧美bt| 浪潮色综合久久天堂| 亚洲精品韩国| 欧美一级淫片aaaaaaa视频| 开心色5月久久精品| 亚洲精品久久久蜜桃| 欧美日韩在线精品一区二区三区| 亚洲一区图片| 99精品免费网| 国产精品综合久久久| 久久久精品国产免费观看同学| 欧美激情视频在线播放| 亚洲网站啪啪| 欧美一区二区三区另类| 午夜伦欧美伦电影理论片| 另类国产ts人妖高潮视频| 亚洲国产精品久久久久秋霞影院 | 欧美久久一级| 亚洲欧美国产va在线影院| 亚洲免费观看高清完整版在线观看熊| 欧美日韩亚洲一区二区| 先锋影音一区二区三区| 欧美顶级少妇做爰| 亚洲小视频在线| 国语自产精品视频在线看抢先版结局 | 亚洲欧美日韩区| 在线不卡中文字幕| 性欧美在线看片a免费观看| 欧美va亚洲va日韩∨a综合色| 一区二区三区精品久久久| 国产色视频一区| 欧美大片网址| 午夜视频在线观看一区二区三区| 欧美激情一区二区三区在线视频| 亚洲色诱最新| 尤物在线精品| 国产精品福利影院| 老司机久久99久久精品播放免费| 一区二区三区国产精华| 久久这里有精品15一区二区三区| 国产欧美日韩一区二区三区在线观看| 女女同性精品视频| 午夜在线观看欧美| 亚洲精品久久久久久下一站 | 久色成人在线| 亚洲永久免费观看| 亚洲成人原创| 国产伦精品一区二区三区照片91| 欧美成人在线免费观看| 欧美亚洲综合网| 亚洲美女网站| 亚洲视频在线播放| 1000部精品久久久久久久久| 国产精品久久久久秋霞鲁丝| 蜜桃视频一区| 欧美在线国产精品| 在线视频欧美精品| 亚洲高清自拍| 久久婷婷蜜乳一本欲蜜臀| 亚洲视频在线一区观看| 亚洲电影av在线| 国产欧美精品xxxx另类| 欧美精品三级| 久久一区二区视频| 亚洲国产另类久久精品| 狂野欧美激情性xxxx| 亚洲欧美日韩精品久久久久| 亚洲三级国产| 尤物精品在线| 国产亚洲一二三区| 国产精品狼人久久影院观看方式| 欧美激情亚洲另类| 麻豆av一区二区三区|