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

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 閱讀(1902) 評論(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久久久久久www| 亚洲综合精品自拍| 久久精品国产v日韩v亚洲 | 麻豆成人精品| 欧美日韩欧美一区二区| 国产精品专区第二| 亚洲国产精品成人久久综合一区| 99国内精品久久| 欧美中文在线观看| 亚洲国产精品久久久久秋霞影院| 一区二区三区你懂的| 欧美在线三区| 欧美四级在线| 黄色在线一区| 亚洲激情综合| 欧美一区免费视频| 欧美国产成人精品| 亚洲午夜视频在线| 久久久久久久综合| 欧美丝袜一区二区三区| 亚洲激情电影在线| 欧美主播一区二区三区| 亚洲精品中文字幕在线观看| 欧美在线观看网站| 欧美午夜大胆人体| 亚洲欧洲日本mm| 久久久久一区| 亚洲一区二区三区欧美| 欧美激情在线观看| 在线日韩中文字幕| 玖玖视频精品| 欧美一区在线直播| 国产精品美女久久久久av超清 | 免费成人av在线看| 国产日韩精品一区二区三区在线| 亚洲破处大片| 老司机午夜免费精品视频| 亚洲中午字幕| 国产精品久久久久久久一区探花 | 欧美va天堂在线| 午夜精品久久久久久久蜜桃app| 欧美日韩国产精品成人| 亚洲黄色成人久久久| 免费观看在线综合| 久久久噜噜噜久久中文字幕色伊伊 | 在线观看不卡av| 久久免费视频在线观看| 午夜精品在线| 国产欧美va欧美不卡在线| 亚洲欧美在线高清| 夜夜嗨av一区二区三区中文字幕 | 亚洲视频精品| 国产精品久久久久av免费| 一区二区三区三区在线| 99av国产精品欲麻豆| 欧美日韩亚洲一区二区三区四区| 91久久综合| 亚洲欧洲综合| 亚洲欧美日韩专区| 一区二区欧美激情| 亚洲三级影院| 欧美视频1区| 午夜久久美女| 午夜亚洲性色福利视频| 国产一区二区三区在线观看免费视频 | 久久国产免费| 久久黄金**| 亚洲国产裸拍裸体视频在线观看乱了| 久久一区欧美| 欧美/亚洲一区| 亚洲精品系列| 9色国产精品| 国产欧美亚洲精品| 久久综合图片| 欧美日韩国产在线播放| 欧美在线不卡| 欧美www视频| 午夜视频在线观看一区| 久久精品国产亚洲精品| 亚洲乱码国产乱码精品精可以看| 一区二区三区国产在线| 国产一区91| 亚洲国产综合在线看不卡| 国产精品九九久久久久久久| 久久综合色一综合色88| 欧美视频中文字幕在线| 裸体一区二区| 国产精品网站在线| 亚洲国产精品99久久久久久久久| 国产精品久久久久av免费| 欧美成人精品福利| 国产精品久久久久久久久久免费看 | 欧美日韩国产一区二区三区| 久久精品一区二区国产| 欧美精品在线观看91| 久久午夜羞羞影院免费观看| 欧美日韩精品一区二区三区四区| 久色婷婷小香蕉久久| 国产精品老女人精品视频| 亚洲国产mv| 极品av少妇一区二区| 夜夜嗨av色一区二区不卡| 亚洲国产第一页| 欧美中文字幕在线播放| 亚洲综合色丁香婷婷六月图片| 美女图片一区二区| 久久精品国产亚洲5555| 欧美三级电影一区| 亚洲精品裸体| 亚洲另类在线一区| 欧美成人国产一区二区| 久久伊伊香蕉| 国产主播一区| 欧美一区二区免费视频| 国产精品hd| 国产拍揄自揄精品视频麻豆| 亚洲国产精品va在线看黑人动漫| 国产午夜精品全部视频在线播放 | 国产精品男gay被猛男狂揉视频| 亚洲精品国产精品国自产在线| 亚洲高清免费| 久久综合伊人77777麻豆| 久久蜜桃资源一区二区老牛| 国产一区二区av| 欧美一级播放| 久久久精品免费视频| 国产亚洲一区二区精品| 欧美一二三视频| 久久久久九九九九| 激情久久影院| 久久综合久久综合这里只有精品| 欧美电影免费观看高清| 亚洲精品一区在线观看| 欧美日韩免费高清| 亚洲一区二区精品在线观看| 欧美一级在线亚洲天堂| 国产亚洲精品v| 久久女同精品一区二区| 欧美激情在线| 这里只有精品在线播放| 国产精品视频1区| 欧美一区在线直播| 亚洲电影第三页| 亚洲一区二区在线免费观看视频| 国产精品美女www爽爽爽| 欧美一区二区三区免费视频| 免费成人av| 一区二区三区欧美在线观看| 国产精品素人视频| 久久中文久久字幕| 日韩视频一区二区三区在线播放免费观看 | 亚洲神马久久| 久久精品日韩欧美| 亚洲国产美女久久久久| 欧美日韩国产一区二区| 午夜精品美女久久久久av福利| 久久久天天操| 一区二区免费在线观看| 国产一区二区三区成人欧美日韩在线观看 | 亚洲图片你懂的| 国产农村妇女毛片精品久久麻豆| 久久久久久久一区二区三区| 亚洲欧洲精品一区| 久久久久久久久久久成人| 亚洲欧洲一区二区三区在线观看 | 制服丝袜亚洲播放| 欧美专区第一页| 亚洲日本免费| 国产区精品在线观看| 欧美成人精品激情在线观看| 亚洲图片欧美午夜| 欧美韩国日本综合| 香蕉成人伊视频在线观看| 亚洲精品日日夜夜| 国产无一区二区| 欧美片在线播放| 久热精品视频| 午夜久久久久久| 一本色道久久88综合亚洲精品ⅰ| 玖玖综合伊人| 久久激情视频| 亚洲欧美激情四射在线日| 亚洲美女区一区| 伊人成人网在线看| 国产精品香蕉在线观看| 欧美日韩亚洲综合| 欧美黄色成人网| 欧美成年人视频| 久久久久五月天| 久久国产精彩视频|