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

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 閱讀(1894) 評論(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>
            亚洲图片激情小说| 欧美一区二区三区四区在线观看 | 亚洲精品免费观看| 亚洲第一免费播放区| 欧美精品乱人伦久久久久久| 午夜久久99| 欧美成人a视频| 亚洲你懂的在线视频| 亚洲国产91色在线| 国产美女精品免费电影| 一区二区在线视频| 国产精品视频午夜| 欧美日韩成人综合天天影院| 欧美日韩一区二区三区高清| 蜜乳av另类精品一区二区| 午夜久久久久久| 亚洲电影自拍| 欧美在线免费视屏| 激情丁香综合| 亚洲人成亚洲人成在线观看图片| 韩日欧美一区| 亚洲国产高清视频| 夜夜狂射影院欧美极品| 国产在线成人| 激情六月综合| 国产精品视频不卡| 中日韩视频在线观看| 久久久久久综合| 91久久精品日日躁夜夜躁国产| 最新亚洲视频| 午夜精品视频在线观看| 性欧美精品高清| 欧美一区二区三区啪啪| 久久久久久久高潮| 激情久久婷婷| 午夜精品视频在线观看一区二区| 亚洲高清久久| 久久夜色精品国产| 国产亚洲精品久久飘花 | 久久先锋资源| 亚洲欧美网站| 久久精品官网| 亚洲二区在线| 亚洲国产精品成人| 欧美激情视频免费观看| 亚洲精品乱码久久久久久| 欧美日本亚洲视频| 国产精品女主播一区二区三区| 欧美一区午夜精品| 亚洲狠狠丁香婷婷综合久久久| 99爱精品视频| 欧美专区亚洲专区| 欧美一区午夜精品| 亚洲久久成人| 欧美一区二区三区免费在线看| 欧美一区二区日韩| 久久久国产精品亚洲一区| 亚洲电影在线| 亚洲国产日韩美| 久久精品国产综合精品| 性欧美大战久久久久久久久| 亚洲全黄一级网站| 欧美主播一区二区三区| 国产精品一区二区在线| 亚洲第一免费播放区| 久久综合久久综合九色| 欧美日本在线视频| 欧美三区在线视频| 亚洲精品1234| 久久福利电影| 久久视频这里只有精品| 亚洲伦伦在线| 国产精品色婷婷| 激情亚洲一区二区三区四区| 亚洲最黄网站| 亚洲精品一二| 亚洲精品国产视频| 嫩模写真一区二区三区三州| 亚洲亚洲精品在线观看 | 亚洲在线播放| 看欧美日韩国产| 亚洲片在线资源| 国产精品―色哟哟| 欧美在线视频免费观看| 国产一区91| 国产一区二区av| 久久国产精品99精品国产| 亚洲午夜在线观看视频在线| 国产精品久久夜| 亚洲一级网站| 亚洲电影在线观看| 久久综合精品一区| 亚洲精品免费看| 一区二区三区 在线观看视| 国产精品成人一区二区三区夜夜夜| 久久久久高清| 狂野欧美激情性xxxx欧美| 日韩一二三在线视频播| 亚洲女优在线| 亚洲激情在线观看视频免费| 在线视频欧美日韩| 一区视频在线播放| 一本一本大道香蕉久在线精品| 国产精品一区二区在线观看网站 | 亚洲第一中文字幕| 亚洲日本免费电影| 国产精品国内视频| 国产日韩欧美亚洲一区| 亚洲欧美日韩爽爽影院| 亚洲大胆美女视频| 亚洲一二三区精品| 亚洲国产黄色| 亚洲欧美成人一区二区三区| 亚洲精品日韩在线| 欧美中文日韩| 亚洲欧美日韩国产成人| 欧美顶级少妇做爰| 久久久久久亚洲精品杨幂换脸 | 久久精品99国产精品| 9久re热视频在线精品| 久久精品30| 午夜精品短视频| 欧美激情第五页| 免费欧美日韩国产三级电影| 欧美午夜不卡| 亚洲欧洲日产国产综合网| 狠狠色狠狠色综合日日tαg| 亚洲在线黄色| 一本到高清视频免费精品| 久久亚洲精品网站| 香蕉久久夜色精品国产使用方法| 欧美激情二区三区| 老司机成人在线视频| 国产乱码精品一区二区三| 亚洲精品一区二| 亚洲激情精品| 久久久免费精品| 久久人人97超碰精品888| 国产日产欧美a一级在线| 一区二区三区黄色| 日韩网站在线| 欧美巨乳波霸| 99精品福利视频| 99视频国产精品免费观看| 欧美 日韩 国产 一区| 亚洲第一视频网站| 一个色综合导航| 一本一本a久久| 欧美日韩国产首页在线观看| 亚洲狠狠丁香婷婷综合久久久| 亚洲三级影院| 欧美日韩视频在线一区二区观看视频 | 亚洲国产精品一区二区www在线| 亚洲国产成人午夜在线一区| 老鸭窝91久久精品色噜噜导演| 欧美激情一区在线观看| 亚洲精品一区久久久久久| 欧美日韩国产成人在线91| 99视频在线精品国自产拍免费观看 | 久久国产精品久久w女人spa| 樱花yy私人影院亚洲| 国产精品爱啪在线线免费观看| 亚洲欧洲美洲综合色网| 欧美日韩国产丝袜另类| 久久精品国产精品| 亚洲国产另类久久精品| 国语自产精品视频在线看8查询8| 欧美一区中文字幕| 美女精品国产| 在线一区二区三区四区| 国产美女扒开尿口久久久| 久久精品亚洲一区二区| 亚洲激情成人在线| 欧美在线视频二区| 亚洲美女色禁图| 国产精品欧美经典| 久久免费黄色| 亚洲视频电影在线| 欧美二区在线播放| 一区二区免费在线视频| 国产亚洲欧美一区二区| 免费在线一区二区| 亚洲一区二区视频在线| 噜噜噜91成人网| 先锋亚洲精品| 99精品视频免费观看| 国产一本一道久久香蕉| 欧美日韩免费观看一区三区 | 国内精品久久国产| 免费日韩精品中文字幕视频在线| 亚洲日本免费| 久久视频国产精品免费视频在线| 亚洲精品视频在线播放| 亚洲精品视频在线观看网站| 欧美在线二区| 亚洲视频欧美视频| 亚洲一区二区三区精品动漫| 久久久久久亚洲精品杨幂换脸| 在线视频欧美日韩| 国产一区视频网站|