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

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 閱讀(1905) 評論(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国产精品| 黄色成人av网| 国产精品日韩欧美大师| 欧美激情一区二区久久久| 欧美亚洲网站| 亚洲专区一区二区三区| 亚洲日本激情| 欧美插天视频在线播放| 久久久99爱| 欧美一区三区二区在线观看| 日韩亚洲视频在线| 亚洲精品1区| 亚洲国产一二三| 亚洲成人在线视频网站| 好看的亚洲午夜视频在线| 国产精品久久久久秋霞鲁丝| 欧美精品在线观看播放| 欧美成人免费va影院高清| 久久午夜国产精品| 久久九九国产| 久久久一区二区| 久久精品女人| 久久久久久久999精品视频| 欧美一区二视频| 欧美一区二区三区四区在线观看地址 | 亚洲成人自拍视频| 欧美v日韩v国产v| 欧美成人一品| 亚洲福利视频在线| 亚洲激情在线| 99综合在线| 亚洲视频一区二区在线观看| 在线视频中文亚洲| 亚洲性xxxx| 午夜精品一区二区三区在线播放| 午夜精品福利视频| 欧美在线免费观看视频| 久久―日本道色综合久久| 久久综合久久美利坚合众国| 免费视频一区二区三区在线观看| 欧美承认网站| 欧美日韩妖精视频| 国产伦一区二区三区色一情| 国产一区二区三区最好精华液| 好男人免费精品视频| 亚洲国产另类精品专区| 99视频一区二区三区| 亚洲一二三级电影| 久久成人18免费观看| 久久综合国产精品| 亚洲国产美女久久久久| 中文日韩在线| 久久精品夜色噜噜亚洲a∨ | 国产一区日韩二区欧美三区| 激情综合视频| 亚洲精品影视| 欧美一区二区三区在线免费观看| 久久三级福利| 亚洲人成毛片在线播放女女| 中日韩男男gay无套| 亚洲欧美激情四射在线日 | 欧美成人精品影院| 亚洲开发第一视频在线播放| 亚洲综合第一| 欧美大色视频| 国产精品美女一区二区在线观看| 黄色另类av| 久久久久国内| 欧美一区2区三区4区公司二百| 久久女同互慰一区二区三区| 欧美日韩国产专区| 国产欧美不卡| 亚洲精品一区在线| 欧美一区二区三区四区视频| 欧美69视频| 亚洲一区二区高清| 免费观看在线综合| 国产精品免费一区二区三区观看| 亚洲国产日韩欧美综合久久| 午夜精品三级视频福利| 欧美黄网免费在线观看| 亚洲欧美视频在线观看视频| 欧美成人精品一区| 国产亚洲精品成人av久久ww| 99av国产精品欲麻豆| 久久久噜噜噜久久中文字幕色伊伊 | 久久久亚洲高清| 99精品热视频| 蜜桃av综合| 国产亚洲精品久久久久婷婷瑜伽 | 你懂的网址国产 欧美| 一区二区三区久久精品| 欧美xxxx在线观看| 国产在线日韩| 午夜精品国产更新| 亚洲麻豆av| 欧美福利视频| 在线色欧美三级视频| 久久国产精品久久久久久电车| 亚洲精品美女在线观看| 久久中文欧美| 精品1区2区3区4区| 久久精品国产欧美亚洲人人爽| 一区二区三区精品| 欧美日韩另类国产亚洲欧美一级| 91久久在线| 欧美chengren| 久久人人爽人人爽| 极品少妇一区二区| 久久久国产一区二区三区| 亚洲网站视频| 国产精品久久久久7777婷婷| 宅男噜噜噜66国产日韩在线观看| 亚洲国产欧美一区| 欧美成人午夜影院| 亚洲黄色在线观看| 欧美国产一区二区| 免费久久99精品国产自| 在线免费观看一区二区三区| 久久亚洲综合| 久久久国际精品| 在线日韩中文| 欧美国产免费| 欧美黄色网络| 99精品国产在热久久下载| 亚洲日本黄色| 欧美午夜性色大片在线观看| 亚洲视频在线观看| 亚洲深爱激情| 国产日韩免费| 久久日韩精品| 最新成人av网站| 亚洲高清不卡一区| 免费观看久久久4p| 久久这里只有| 日韩一区二区精品| 一个色综合av| 国产日韩在线一区| 久久躁日日躁aaaaxxxx| 狼狼综合久久久久综合网| 亚洲激情亚洲| 99国产精品视频免费观看| 国产精品男女猛烈高潮激情| 久久成人免费日本黄色| 久久精品国产精品亚洲综合| 亚洲国产精品一区二区三区| 亚洲国产专区| 国产精品久久久久毛片大屁完整版 | 欧美日韩在线播放一区二区| 亚洲午夜羞羞片| 亚洲欧美视频一区| 黄网站免费久久| 欧美激情成人在线| 欧美午夜精品久久久久久孕妇 | 亚洲黄色一区二区三区| 欧美日韩午夜剧场| 欧美影院在线播放| 久久深夜福利免费观看| 日韩一级大片| 亚洲欧美日韩综合| 亚洲国产清纯| 亚洲视频你懂的| 影音先锋久久| 一本综合精品| 亚洲第一区在线观看| 9人人澡人人爽人人精品| 国产又爽又黄的激情精品视频 | 美女主播一区| 欧美日韩中文字幕精品| 久久精选视频| 欧美日韩国产黄| 久久看片网站| 欧美三级电影网| 麻豆精品在线视频| 国产精品国产精品| 欧美大尺度在线| 国产精品久久久久久久久果冻传媒| 久久久亚洲精品一区二区三区| 欧美精品三区| 久久综合五月天婷婷伊人| 欧美视频在线观看一区| 欧美r片在线| 国产欧美一区二区三区在线看蜜臀| 欧美激情2020午夜免费观看| 国产欧美精品在线播放| 亚洲欧洲日产国产网站| 国内视频一区| 亚洲午夜在线观看| 日韩亚洲精品电影| 久久久国产成人精品| 午夜精品区一区二区三| 欧美日本二区| 免费观看成人网| 国产亚洲欧美日韩美女| 一区二区三区四区五区在线| 亚洲精品欧美精品| 麻豆精品国产91久久久久久| 蜜臀va亚洲va欧美va天堂 | 亚洲另类视频|