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

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>
            亚洲国产精品www| 欧美激情一区二区| 亚洲永久免费| 美女图片一区二区| 亚洲人成在线观看一区二区| 欧美一区二区三区婷婷月色| 国产精品电影网站| 亚洲日本欧美日韩高观看| 久久精品青青大伊人av| 亚洲午夜一区二区三区| 欧美激情综合在线| 亚洲精品视频一区二区三区| 欧美电影免费观看高清| 美女成人午夜| 亚洲电影免费在线 | 欧美高清视频一区| 久久午夜国产精品| 亚洲高清视频的网址| 麻豆精品91| 久久久水蜜桃av免费网站| 国产一区二区在线观看免费| 亚洲午夜激情| 亚洲色图自拍| 国产精品每日更新在线播放网址| 亚洲一区二区三区在线播放| 99re热这里只有精品视频| 久久国产日本精品| 在线观看一区二区精品视频| 久久永久免费| 欧美插天视频在线播放| 99国内精品久久| 亚洲乱码一区二区| 亚洲一品av免费观看| 国产精品日日摸夜夜添夜夜av| 欧美一级欧美一级在线播放| 亚洲一二三四区| 国产日韩欧美不卡| 免费的成人av| 欧美精品久久久久久| 国产精品视频一二三| 久久久久.com| 亚洲高清在线视频| 亚洲成人资源网| 久久综合网色—综合色88| 欧美一区二视频在线免费观看| 亚洲在线观看| 欧美中文字幕久久| 亚洲国产成人精品女人久久久| 亚洲国产欧美国产综合一区| 欧美日韩一级黄| 久久精品日韩欧美| 欧美福利影院| 久久精品亚洲乱码伦伦中文| 久久欧美中文字幕| 国产精品99久久不卡二区| 午夜精品一区二区三区在线| 亚洲国产精品成人综合色在线婷婷| 亚洲精品国产精品国自产在线| 国产精品你懂得| 欧美成人精品一区| 国产精品久久久爽爽爽麻豆色哟哟| 久久亚裔精品欧美| 欧美日韩www| 久久视频一区| 国产精品久久久久久户外露出 | 日韩一级二级三级| 久久av二区| 亚洲欧美激情视频| 模特精品在线| 久久亚洲午夜电影| 国产精品国产三级国产a| 欧美肥婆在线| 国产在线麻豆精品观看| 夜夜爽av福利精品导航 | 欧美福利视频网站| 国产精品v欧美精品v日韩精品| 久久久久99| 国产精品久久久久毛片软件| 欧美a级大片| 久久精品国产视频| 亚洲欧美日韩国产综合| 欧美激情va永久在线播放| 老司机免费视频久久| 国产日韩精品久久| 亚洲综合欧美| 午夜精品免费| 国产精品va在线播放我和闺蜜| 亚洲黄色三级| 亚洲人精品午夜| 蜜臀av国产精品久久久久| 裸体一区二区三区| 在线观看欧美视频| 久久久伊人欧美| 美乳少妇欧美精品| 亚洲第一中文字幕| 久久久亚洲国产天美传媒修理工| 久久蜜桃资源一区二区老牛| 国产一区二区三区高清播放| 亚洲日本乱码在线观看| 久久久久九九九九| 国产欧美日韩在线播放| 亚洲综合色视频| 欧美亚洲视频在线看网址| 国产精品成人一区| 欧美在线亚洲一区| 国产日韩欧美中文| 亚洲一区免费| 久久久精品五月天| 午夜精品免费在线| 香蕉av777xxx色综合一区| 亚洲系列中文字幕| 亚洲精品午夜| 亚洲精品国精品久久99热一| 亚洲国产日韩欧美在线图片| 女生裸体视频一区二区三区 | 老司机精品导航| 亚洲免费综合| 欧美一级专区| 欧美巨乳在线| 国产农村妇女毛片精品久久麻豆 | 久久精品免费观看| 亚洲欧美久久| 欧美aaa级| 久久裸体视频| 欧美成人精品一区| 亚洲性视频网址| 国产精品网站在线观看| 欧美福利视频一区| 国产自产v一区二区三区c| 另类酷文…触手系列精品集v1小说| 国产一级久久| 欧美电影电视剧在线观看| 99精品国产福利在线观看免费| 亚洲无线视频| 久久久久久电影| 亚洲精品国久久99热| 欧美性jizz18性欧美| 久久成人免费电影| 亚洲精品国产品国语在线app| 亚洲欧美成人精品| 激情91久久| 欧美视频不卡| 久久精品国产综合精品| 亚洲精品乱码久久久久| 久久激情一区| 一区二区av| 国语自产精品视频在线看| 欧美剧在线免费观看网站| 香蕉成人伊视频在线观看| 午夜精品一区二区三区在线视| 欧美精品一区二区三区蜜桃| 国产日韩欧美电影在线观看| 亚洲欧美在线aaa| 欧美一区二区在线免费播放| 亚洲日本中文字幕区| 欧美精品一区二区久久婷婷| 亚洲九九爱视频| 欧美国产大片| 亚洲欧美日韩精品在线| 1024成人| 欧美一区二区三区精品| 亚洲人成在线观看网站高清| 米奇777在线欧美播放| 国产一区二区三区无遮挡| 欧美连裤袜在线视频| 久久理论片午夜琪琪电影网| 亚洲影院在线观看| 99热在这里有精品免费| 亚洲电影免费观看高清完整版在线观看 | 欧美天堂亚洲电影院在线播放| 乱中年女人伦av一区二区| 久久国产精品久久久久久久久久| 一本综合久久| 99国产精品99久久久久久粉嫩| 欧美国产日韩一区二区三区| 美女精品在线观看| 久久一区免费| 蜜桃av综合| 欧美国产三区| 亚洲国产欧美国产综合一区 | 欧美夜福利tv在线| 午夜精品久久久久久久久| 亚洲欧美日韩精品久久久| 欧美亚洲视频在线观看| 欧美一区二区三区精品电影| 久久精品国产欧美亚洲人人爽| 久久久亚洲欧洲日产国码αv| 久久综合久色欧美综合狠狠 | 欧美天堂亚洲电影院在线观看| 欧美日本亚洲韩国国产| 欧美视频在线观看| 国产精品欧美一区二区三区奶水| 国产精品自拍小视频| 韩国精品一区二区三区| 亚洲电影免费| 一区二区三区高清视频在线观看| 亚洲一区欧美二区| 久久精品一区蜜桃臀影院| 欧美激情一区二区久久久| 一本在线高清不卡dvd |