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

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 閱讀(1906) 評論(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>
            亚洲高清毛片| 国产精品激情| 午夜精品亚洲| 欧美了一区在线观看| 久久久亚洲精品一区二区三区 | 久久免费视频一区| 国产精品黄页免费高清在线观看| 欧美高清视频一区二区| 国产一区深夜福利| 亚洲免费一在线| 亚洲视频国产视频| 欧美久久电影| 亚洲国产欧美日韩另类综合| 好看不卡的中文字幕| 亚洲欧美中文另类| 欧美一级电影久久| 国产精品美女久久久| 在线亚洲国产精品网站| 亚洲视频观看| 国产精品成人aaaaa网站| 亚洲日本欧美天堂| 日韩香蕉视频| 欧美日韩少妇| 一本色道久久综合| 亚洲午夜小视频| 国产精品国产三级国产aⅴ入口 | 久久黄金**| 久久婷婷蜜乳一本欲蜜臀| 国产欧美一区二区三区在线老狼 | 欧美一站二站| 国产精品三上| 欧美亚洲三级| 另类av一区二区| 亚洲国产成人在线| 欧美激情精品久久久久久| 亚洲激情影视| 亚洲伊人第一页| 国产日韩欧美亚洲| 久久久久久久波多野高潮日日 | 亚洲第一在线综合网站| 亚洲人成亚洲人成在线观看| 欧美激情综合| 亚洲男女自偷自拍图片另类| 久久精品国产999大香线蕉| 国产一区二区欧美日韩| 久久免费国产| 亚洲美女视频在线观看| 亚洲欧美三级伦理| 韩日欧美一区| 欧美紧缚bdsm在线视频| 亚洲一区二区三区色| 久久精品人人做人人爽电影蜜月| 一区在线观看| 欧美日韩一区二区三区四区五区 | 一本色道久久88亚洲综合88| 国产精品海角社区在线观看| 小处雏高清一区二区三区| 免费在线亚洲| 亚洲在线网站| 亚洲国产高潮在线观看| 欧美午夜无遮挡| 久久九九免费视频| 日韩视频一区二区| 巨乳诱惑日韩免费av| 一区二区三区四区在线| 国内精品久久久久久久97牛牛| 欧美wwwwww| 校园春色国产精品| 亚洲三级免费观看| 久久人91精品久久久久久不卡| 亚洲精一区二区三区| 国产日韩欧美精品综合| 欧美激情精品久久久六区热门| 午夜影院日韩| 夜夜爽夜夜爽精品视频| 亚洲欧美日韩在线| 亚洲激情av| 国产情人综合久久777777| 欧美激情在线狂野欧美精品| 欧美一级视频精品观看| 亚洲精选视频免费看| 麻豆91精品91久久久的内涵| 亚洲综合欧美日韩| 亚洲精品国产日韩| 韩国v欧美v日本v亚洲v | 免费在线观看精品| 香蕉视频成人在线观看| 一区二区三区欧美视频| 欧美激情性爽国产精品17p| 久久久精品2019中文字幕神马| 中日韩视频在线观看| 亚洲激情影视| 1024欧美极品| 一区二区亚洲精品国产| 国产视频综合在线| 国产精品色网| 国产精品人成在线观看免费| 欧美视频在线一区二区三区| 欧美区亚洲区| 欧美精品啪啪| 欧美精品一区在线发布| 欧美成人午夜免费视在线看片 | 国产精品ⅴa在线观看h| 欧美日韩爆操| 欧美精品激情| 欧美高清在线| 欧美精品成人91久久久久久久| 久久亚洲捆绑美女| 久久精品人人| 久久综合中文字幕| 麻豆精品网站| 欧美成人午夜免费视在线看片| 久久米奇亚洲| 免费观看成人网| 欧美电影免费观看高清| 欧美国产丝袜视频| 欧美日韩精品在线观看| 欧美四级电影网站| 国产精品羞羞答答xxdd| 国产日韩欧美综合| 国内精品美女av在线播放| 黑人巨大精品欧美一区二区小视频 | 99视频热这里只有精品免费| 日韩亚洲精品电影| 亚洲午夜久久久| 午夜精品福利电影| 久久久av毛片精品| 欧美国产精品日韩| 欧美日韩免费观看中文| 国产精品久久中文| 国内免费精品永久在线视频| 亚洲国产精品成人综合| 日韩午夜在线| 欧美制服丝袜第一页| 免费久久99精品国产| 亚洲欧洲一级| 欧美一级在线视频| 欧美国产激情二区三区| 国产精品久久久久久久久久ktv| 国产日韩欧美三级| 最近看过的日韩成人| 亚洲综合电影一区二区三区| 久久久97精品| 亚洲精品日产精品乱码不卡| 亚洲女人av| 欧美不卡高清| 国产亚洲精品一区二区| 亚洲另类自拍| 久久精品亚洲一区| 亚洲精品偷拍| 久久久久国产精品www| 欧美日韩国产综合在线| 国产真实乱偷精品视频免| 日韩亚洲精品在线| 久久人人97超碰人人澡爱香蕉 | 中日韩午夜理伦电影免费| 欧美在线观看视频在线| 欧美激情第3页| 国产一区二区三区久久久| 中文久久精品| 亚洲大片av| 欧美制服丝袜第一页| 欧美精品一区二区三区蜜臀| 黄色亚洲免费| 欧美一级淫片播放口| 亚洲精品一区二区三区福利| 久久精品国产亚洲aⅴ| 国产精品jizz在线观看美国 | 亚洲成人资源网| 欧美亚洲日本一区| 亚洲剧情一区二区| 久久综合久久综合久久| 国产一区二区三区久久悠悠色av| 亚洲一区成人| 亚洲三级性片| 欧美国产欧美亚洲国产日韩mv天天看完整 | 牛人盗摄一区二区三区视频| 亚洲欧美激情四射在线日 | 久久久久久久久伊人| 亚洲视频碰碰| 欧美日韩亚洲激情| 日韩视频一区| 亚洲高清一二三区| 久久综合伊人| 亚洲国产精品第一区二区三区| 久久久久久久久综合| 亚洲欧美日韩中文视频| 国产精品久久久久免费a∨| 一区二区三区免费网站| 91久久夜色精品国产网站| 欧美aaa级| 亚洲精品美女久久久久| 欧美激情亚洲自拍| 蜜桃av噜噜一区| 91久久一区二区| 亚洲黄色成人网| 欧美日韩国产小视频| 在线亚洲欧美视频| 一区二区三区日韩精品| 国产精品久久久久婷婷|