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

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>
            国产精品久久久久77777| 欧美日韩免费观看中文| 国产亚洲一二三区| 久久久999精品免费| 欧美一级淫片播放口| 精品96久久久久久中文字幕无| 麻豆国产va免费精品高清在线| 久久在线91| 9人人澡人人爽人人精品| 一本色道久久88综合亚洲精品ⅰ | 久久综合婷婷| 日韩午夜av电影| 亚洲午夜精品17c| 精品不卡一区二区三区| 亚洲国产日日夜夜| 国产精品久久久久999| 老司机精品福利视频| 欧美国产极速在线| 亚洲一区久久久| 久久蜜桃资源一区二区老牛| 9色国产精品| 久久国产精品毛片| 一本久道久久综合狠狠爱| 亚洲免费在线播放| 亚洲第一黄色| 亚洲一区二区三区久久 | 欧美精品免费在线| 久久精品国产精品亚洲精品| 免费国产一区二区| 欧美资源在线观看| 欧美日韩一区二区三区在线| 另类亚洲自拍| 国产精品福利网站| 亚洲第一页自拍| 国产在线精品一区二区夜色| 亚洲精品久久久一区二区三区| 国内久久婷婷综合| 一区二区三区四区国产精品| 亚洲三级视频在线观看| 欧美在线视频a| 亚洲欧美在线高清| 欧美日韩久久久久久| 欧美成人国产一区二区| 国产精品一二三四区| 亚洲精品视频免费观看| 亚洲激精日韩激精欧美精品| 欧美一区二区免费视频| 亚洲欧美另类在线| 欧美日韩亚洲天堂| 亚洲欧洲精品一区二区| 亚洲欧洲综合| 久久视频在线视频| 美女精品视频一区| 狠狠入ady亚洲精品经典电影| 亚洲小视频在线| 亚洲欧美日韩国产精品| 欧美午夜不卡视频| 99精品国产99久久久久久福利| 亚洲精品免费在线播放| 欧美激情精品| 亚洲电影免费观看高清完整版| 亚洲福利视频专区| 久久中文字幕导航| 欧美大片免费观看| 欧美日韩福利| 久久久精品国产免大香伊| 国产精品s色| 亚洲欧美国产77777| 午夜欧美精品| 国内精品久久久久影院优| 欧美一区二区在线| 美玉足脚交一区二区三区图片| 精品1区2区3区4区| 牛人盗摄一区二区三区视频| 91久久精品一区二区别| 一区二区欧美视频| 国产精品美女在线| 欧美一区二区福利在线| 免费在线观看成人av| 亚洲三级免费观看| 国产精品v欧美精品∨日韩| 亚洲视频一区二区免费在线观看| 亚洲欧美另类在线| 黄色精品免费| 欧美精品久久99| 亚洲婷婷综合色高清在线 | 亚洲性图久久| 亚洲欧美视频一区| 国产手机视频精品| 榴莲视频成人在线观看| 亚洲精品日韩精品| 欧美诱惑福利视频| 亚洲国产精品ⅴa在线观看| 欧美乱在线观看| 亚洲欧美在线x视频| 欧美激情国产高清| 亚洲在线国产日韩欧美| 狠狠色丁香婷综合久久| 欧美精品久久99| 欧美一区二区三区免费观看| 亚洲欧洲一区| 久久久久国产精品www| 99国产精品久久久久老师| 国产欧美日韩亚洲| 欧美欧美全黄| 久久青草欧美一区二区三区| 久久福利毛片| 一区二区欧美激情| 欧美激情精品久久久久久黑人| 午夜激情综合网| 亚洲精品一区二区在线| 国产日本欧美一区二区三区在线| 欧美福利一区| 久久精选视频| 午夜精品成人在线视频| 亚洲精品美女在线| 欧美国产日韩精品免费观看| 久久国产精品久久久久久| 一本久久精品一区二区| 亚洲国产欧美国产综合一区| 国产日韩精品一区二区三区 | 亚洲一卡久久| 99国产精品99久久久久久粉嫩| 欧美电影专区| 久久性色av| 久久午夜电影网| 久久精品亚洲乱码伦伦中文| 亚洲欧美日韩精品久久亚洲区 | 亚洲欧洲一区二区在线观看| 狠狠爱www人成狠狠爱综合网| 国产精品视频久久| 国产精品高潮呻吟久久av黑人| 欧美国产日韩一区| 欧美二区在线| 欧美岛国激情| 欧美大片免费| 欧美高清在线一区| 欧美黑人一区二区三区| 欧美成人a视频| 欧美国产一区二区| 欧美精品久久久久久久| 欧美另类女人| 国产精品yjizz| 国产欧美视频一区二区| 国产精品五月天| 国产精品丝袜xxxxxxx| 国产精品午夜在线观看| 国产精品系列在线播放| 国产丝袜一区二区| 国内精品嫩模av私拍在线观看| 激情六月综合| 亚洲激情偷拍| 亚洲夜间福利| 久久国产精品一区二区三区四区| 欧美伊人精品成人久久综合97| 久久精品国语| 欧美电影免费网站| 日韩一区二区免费高清| 亚洲香蕉成视频在线观看 | 99国产麻豆精品| 亚洲女同在线| 久久综合久色欧美综合狠狠| 欧美激情乱人伦| 国产精品国产三级欧美二区 | 欧美高清在线视频| 欧美视频1区| 国产视频自拍一区| 亚洲欧洲在线观看| 亚洲女同性videos| 另类综合日韩欧美亚洲| 亚洲人成网站777色婷婷| 亚洲一卡久久| 欧美成人免费va影院高清| 欧美视频在线一区| 狠狠色狠狠色综合日日91app| 亚洲精品国产拍免费91在线| 午夜激情一区| 91久久精品日日躁夜夜躁欧美 | 亚洲精品免费在线观看| 亚洲免费一级电影| 欧美高清不卡| 国产亚洲欧美日韩美女| 99视频精品全国免费| 久久久之久亚州精品露出| 亚洲精品欧洲| 久久亚洲高清| 国产欧美日本在线| 一区二区三区高清不卡| 久久夜色撩人精品| 亚洲深夜福利| 欧美国产日本| 在线播放日韩| 欧美一区2区视频在线观看| 亚洲欧洲在线播放| 久久久久一区二区| 国产精品视频一二三| 99视频+国产日韩欧美| 免费不卡视频| 欧美一级二级三级蜜桃| 国产精品黄视频|