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

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 閱讀(1908) 評論(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>
            亚洲精品字幕| 久久久噜噜噜久久狠狠50岁| 欧美日韩免费观看一区二区三区| 欧美裸体一区二区三区| 亚洲精品裸体| 亚洲国产成人午夜在线一区| 免费精品99久久国产综合精品| 在线成人h网| 欧美电影美腿模特1979在线看| 久久永久免费| 亚洲欧洲午夜| 亚洲精品日韩在线| 欧美日韩视频在线第一区| 亚洲手机视频| 亚洲香蕉网站| 国产精品毛片a∨一区二区三区| 亚洲欧美一区二区三区在线| 亚洲欧美日韩精品久久亚洲区 | 香蕉久久精品日日躁夜夜躁| 亚洲一卡久久| 伊人久久噜噜噜躁狠狠躁| 亚洲欧洲在线播放| 欧美高清视频在线| 欧美日韩国产成人在线观看| 午夜精品国产更新| 久久躁日日躁aaaaxxxx| 中文在线资源观看网站视频免费不卡 | 国产亚洲成av人片在线观看桃| 奶水喷射视频一区| 欧美视频免费在线观看| 久久久99精品免费观看不卡| 亚洲人成小说网站色在线 | 国产一区二区三区精品久久久| 欧美成人免费视频| 国产精品www.| 欧美成人激情视频| 国产精品高清在线| 欧美成人免费网站| 国产精品视频自拍| 亚洲福利精品| 国产欧美日韩另类视频免费观看| 欧美激情第3页| 国产精品一区二区你懂得| 欧美国产欧美亚洲国产日韩mv天天看完整 | 免费观看日韩| 国产精品人人爽人人做我的可爱| 欧美高清视频www夜色资源网| 国产精品久久久久影院亚瑟| 欧美激情成人在线视频| 国产欧亚日韩视频| 日韩一本二本av| 悠悠资源网亚洲青| 亚洲一区二区三区在线| 亚洲欧洲在线免费| 久久精品国产成人| 亚洲午夜久久久久久久久电影院| 亚洲美女黄色| 亚洲成色777777在线观看影院| 亚洲一区日本| 99re热精品| 久久午夜国产精品| 久久成人免费视频| 欧美视频免费在线观看| 亚洲二区精品| 国内外成人免费视频| 一区二区欧美日韩| 亚洲精品一区二区在线| 久久精品麻豆| 欧美在线免费看| 欧美日韩欧美一区二区| 欧美刺激性大交免费视频| 国产日韩欧美一区二区| avtt综合网| 99re6热在线精品视频播放速度| 久久久999精品| 欧美中文字幕久久| 欧美天天影院| 亚洲精品国产日韩| 亚洲激情自拍| 久久亚洲春色中文字幕久久久| 久久福利影视| 国产欧美日韩一区二区三区在线| 一区二区免费在线播放| 一本色道久久综合亚洲精品婷婷| 久久不射网站| 欧美一区二区三区精品| 亚洲一区二区三区精品在线| 欧美激情一区二区| 欧美福利一区| 亚洲高清视频中文字幕| 久久女同精品一区二区| 久久婷婷国产麻豆91天堂| 国产乱码精品一区二区三区忘忧草| 99亚洲一区二区| 一区二区日韩伦理片| 欧美久久久久久| 亚洲国产精品一区二区三区| 亚洲国产高清aⅴ视频| 久久久久国产精品一区| 久久综合久久综合这里只有精品| 国产亚洲va综合人人澡精品| 欧美一区二区| 久久精品官网| 韩国欧美一区| 久久人人爽爽爽人久久久| 久久这里只有精品视频首页| 狠狠色2019综合网| 久久久综合视频| 欧美成人国产一区二区| 亚洲欧洲午夜| 欧美日本韩国一区| 99亚洲视频| 性做久久久久久| 国产亚洲人成网站在线观看| 欧美一区二区视频在线| 久久亚洲综合网| 在线观看亚洲视频| 免费一级欧美片在线播放| 亚洲国产99精品国自产| 日韩网站在线| 欧美高清在线播放| 日韩午夜中文字幕| 亚洲一区综合| 国产亚洲精品v| 久久久久久久久久久久久女国产乱 | 中国亚洲黄色| 国产精品video| 午夜精品福利一区二区三区av| 久久久中精品2020中文| 1024亚洲| 欧美精品亚洲精品| 一区二区三区欧美在线| 欧美在线free| 亚洲国产va精品久久久不卡综合| 久久五月激情| 亚洲精品免费一区二区三区| 亚洲在线中文字幕| 国产视频久久久久| 久久婷婷国产综合国色天香| 亚洲欧洲综合| 亚洲女优在线| 黑人巨大精品欧美一区二区小视频| 狂野欧美激情性xxxx欧美| 亚洲精品视频啊美女在线直播| 亚洲欧美日韩国产成人精品影院| 国产亚洲欧洲997久久综合| 久久夜色精品国产| 亚洲欧洲日本mm| 久久国产视频网站| 欧美大片在线看免费观看| 一本色道久久88综合亚洲精品ⅰ | 一区二区福利| 久久中文字幕一区| 日韩一二在线观看| 国产乱码精品1区2区3区| 性欧美激情精品| 欧美成人精品| 亚洲一区欧美二区| 一区二区在线视频播放| 欧美精品自拍| 亚洲欧美成人精品| 欧美国产免费| 性刺激综合网| 最新日韩av| 国产精品羞羞答答xxdd| 玖玖玖国产精品| 亚洲一级免费视频| 欧美成人按摩| 亚洲在线一区二区| 亚洲国产成人久久| 国产精品久久久亚洲一区| 久久视频这里只有精品| 一区二区三区精品| 麻豆免费精品视频| 在线视频你懂得一区二区三区| 国内精品伊人久久久久av一坑| 免费成人美女女| 西瓜成人精品人成网站| 亚洲三级视频| 久久亚洲欧美国产精品乐播| 亚洲一区二区成人在线观看| 亚洲高清在线| 国产一级一区二区| 欧美日韩另类字幕中文| 久久久久久电影| 亚洲一区二区三区中文字幕在线| 欧美大秀在线观看| 欧美在线日韩在线| 一本色道久久综合亚洲精品不卡 | 免播放器亚洲一区| 午夜精品视频在线观看| 亚洲精品综合久久中文字幕| 国产在线成人| 国产精品青草久久| 欧美日本国产在线| 久热精品在线| 欧美一区二区黄色| 一本久久综合亚洲鲁鲁五月天| 亚洲风情亚aⅴ在线发布| 欧美在线综合|