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

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 閱讀(1913) 評論(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>
            老司机亚洲精品| 亚洲伊人色欲综合网| 国产精品自拍三区| 欧美福利小视频| 国产欧美精品日韩| 日韩午夜在线视频| 91久久精品国产91性色tv| 亚洲午夜视频在线观看| 亚洲精品视频免费| 久久夜色精品国产| 久久国产天堂福利天堂| 欧美午夜一区二区三区免费大片| 欧美成人精品福利| 国产一区久久久| 亚洲女同性videos| 亚洲免费视频网站| 欧美日韩国产精品一区| 亚洲大黄网站| 亚洲国产视频一区二区| 久久久91精品国产| 久久久午夜视频| 国产一区美女| 欧美在线观看视频在线| 久久狠狠亚洲综合| 国产精自产拍久久久久久| 一区二区三区高清在线观看| 一区二区不卡在线视频 午夜欧美不卡在 | 一区二区三区欧美视频| 亚洲精品色婷婷福利天堂| 牛人盗摄一区二区三区视频| 欧美1区视频| 亚洲国产精品久久91精品| 久久综合综合久久综合| 欧美激情1区2区3区| 亚洲国产精品热久久| 免费观看一区| 亚洲国产视频a| 一本久道久久综合中文字幕| 欧美日韩国产成人在线观看| 亚洲精品免费一区二区三区| 中文精品在线| 国产精品日韩高清| 欧美在线播放| 欧美成人午夜免费视在线看片| 亚洲国产精品ⅴa在线观看| 欧美本精品男人aⅴ天堂| 亚洲精品护士| 新片速递亚洲合集欧美合集| 国产日产欧产精品推荐色| 欧美专区中文字幕| 欧美国产亚洲精品久久久8v| 日韩午夜三级在线| 国产精品国产自产拍高清av王其 | 欧美顶级艳妇交换群宴| 亚洲精品四区| 久久精品国内一区二区三区| 在线播放日韩欧美| 欧美日韩福利| 午夜视频在线观看一区| 欧美激情亚洲自拍| 亚洲欧美日韩一区二区| 国内外成人免费激情在线视频网站| 玖玖国产精品视频| 一本大道久久精品懂色aⅴ| 久久精品30| 亚洲精品资源| 国产亚洲精品bv在线观看| 欧美va亚洲va日韩∨a综合色| 一区二区三区欧美成人| 你懂的亚洲视频| 亚洲少妇自拍| 亚洲经典三级| 国产美女扒开尿口久久久| 欧美成人精品激情在线观看| 亚洲一区二区毛片| 亚洲第一在线综合在线| 性8sex亚洲区入口| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲国产成人久久| 国产精品欧美一区喷水| 牛夜精品久久久久久久99黑人| 亚洲一区免费视频| 亚洲人精品午夜在线观看| 久久九九热re6这里有精品| 日韩一区二区精品葵司在线| 国产综合在线视频| 国产精品豆花视频| 欧美激情精品久久久久久| 性欧美1819sex性高清| 99这里只有精品| 亚洲第一精品在线| 噜噜噜噜噜久久久久久91| 亚洲欧美在线磁力| 一本到12不卡视频在线dvd| 伊人久久大香线蕉综合热线| 国产欧美精品va在线观看| 欧美午夜电影完整版| 欧美韩日亚洲| 欧美bbbxxxxx| 免费日韩一区二区| 久久婷婷亚洲| 久久精品在线| 欧美在线免费视屏| 午夜在线成人av| 亚洲主播在线播放| 亚洲一区二区动漫| 99综合在线| 99riav国产精品| 99精品99| 一级日韩一区在线观看| 99热免费精品在线观看| 日韩小视频在线观看| 亚洲伦理在线免费看| 91久久久久久久久久久久久| 亚洲国产91色在线| 亚洲电影在线| 亚洲精品欧洲精品| 日韩午夜高潮| 亚洲永久免费视频| 亚洲欧美日韩国产| 欧美在线电影| 久久人人97超碰国产公开结果| 久久久久久久久岛国免费| 久久婷婷国产综合国色天香| 美女精品视频一区| 欧美日韩精品在线播放| 欧美日韩伊人| 国产日韩精品在线播放| 伊人久久综合| 亚洲毛片在线观看| 亚洲一区二区视频在线观看| 亚洲欧美日韩国产中文| 久久er99精品| 欧美a级片一区| 日韩视频不卡| 亚洲欧美日韩国产成人| 久久午夜精品一区二区| 欧美极品在线视频| 国产精品免费网站在线观看| 国外成人网址| 一区二区欧美日韩视频| 欧美在线视频免费| 亚洲福利一区| 亚洲天堂网在线观看| 久久久久久一区二区| 欧美日本亚洲| 国产一区自拍视频| 亚洲美女视频网| 欧美在线观看视频在线| 欧美~级网站不卡| 99在线精品视频| 久久久久久久性| 欧美日韩免费一区二区三区| 国产色产综合产在线视频| 亚洲人体影院| 久久国产婷婷国产香蕉| 亚洲国产你懂的| 香蕉亚洲视频| 欧美日韩精品免费看| 国产在线精品成人一区二区三区 | 欧美色欧美亚洲高清在线视频| 国产情人综合久久777777| 亚洲精品日韩在线| 久久先锋资源| 亚洲一区二区三区中文字幕在线| 久久免费国产| 国产偷久久久精品专区| 99国产欧美久久久精品| 久久米奇亚洲| 亚洲综合精品自拍| 欧美人成在线视频| 亚洲激情校园春色| 久久久久久婷| 亚洲欧美偷拍卡通变态| 欧美日韩免费区域视频在线观看| 今天的高清视频免费播放成人 | 欧美美女bbbb| 最新亚洲电影| 玖玖在线精品| 欧美一级理论性理论a| 欧美天堂亚洲电影院在线观看 | 亚洲欧美国内爽妇网| 亚洲国产精品一区二区第一页| 欧美综合二区| 国产日韩欧美精品在线| 亚洲欧美伊人| 亚洲视频中文| 欧美午夜一区二区福利视频| 日韩一级二级三级| 亚洲国产精品123| 男人插女人欧美| 亚洲第一精品影视| 麻豆精品视频在线观看| 久久国产精品高清| 国产亚洲欧美一区在线观看| 性色一区二区| 午夜国产精品影院在线观看| 国产精品入口夜色视频大尺度 | 蜜臀久久99精品久久久画质超高清| 国产综合精品一区|