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

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>
            欧美大胆a视频| 亚洲天堂成人在线视频| 99成人在线| 伊人男人综合视频网| 亚洲午夜精品在线| av不卡在线观看| 欧美+亚洲+精品+三区| 久久久精品国产99久久精品芒果| 欧美日韩一级视频| 亚洲国产精品第一区二区三区| 国产日韩欧美二区| 亚洲图片自拍偷拍| 亚洲已满18点击进入久久| 欧美韩日高清| 欧美国产精品v| 在线电影一区| 久久久久欧美精品| 久久欧美肥婆一二区| 国内精品久久久久影院优| 亚洲欧美资源在线| 欧美一区二区福利在线| 国产精品久久久久久亚洲毛片 | 亚洲激情在线播放| 午夜欧美精品| 性欧美1819性猛交| 国产人成一区二区三区影院| 亚洲视频在线观看免费| 西西裸体人体做爰大胆久久久| 欧美四级在线| 亚洲婷婷综合久久一本伊一区| 亚洲性感美女99在线| 国产精品久久久久久久久免费| 一区二区三区**美女毛片 | 午夜老司机精品| 欧美日韩大片| 亚洲最新视频在线| 欧美一区二区三区视频免费播放 | 国产精品99久久久久久宅男| 欧美日韩色一区| 亚洲一区视频| 美女黄毛**国产精品啪啪| 亚洲国产精品成人| 欧美日韩岛国| 午夜精品一区二区三区四区| 久久久久久久久蜜桃| 亚洲国产欧美日韩另类综合| 欧美片第1页综合| 亚洲专区欧美专区| 另类图片综合电影| 亚洲视频第一页| 国产欧美一区二区三区另类精品 | 亚洲欧美日韩精品久久| 久久久免费精品| 亚洲精品免费电影| 国产精品日韩欧美一区| 久久香蕉国产线看观看网| 91久久综合亚洲鲁鲁五月天| 欧美一区二区三区视频在线| 亚洲二区视频在线| 欧美性一二三区| 久久久久久成人| 亚洲精选视频免费看| 久久久精品国产一区二区三区 | 午夜视频一区二区| 亚洲第一中文字幕| 国产精品久久久久久一区二区三区| 欧美一区二区三区另类| 亚洲片在线观看| 久久婷婷丁香| 亚洲午夜视频在线| 亚洲黄色在线视频| 国产欧美一区二区精品仙草咪| 欧美成人免费在线观看| 欧美亚洲一区二区三区| 亚洲免费大片| 欧美大片免费观看| 久久久91精品国产| 亚洲欧美日韩国产一区二区| 亚洲精品一区在线观看| 激情婷婷欧美| 国产情人节一区| 欧美性一区二区| 欧美精品久久久久a| 久久午夜精品一区二区| 亚洲欧美一区二区在线观看| 日韩一级片网址| 亚洲国产日韩在线| 牛牛精品成人免费视频| 久久久国产精品一区二区中文 | 欧美电影免费观看大全| 久久久久网站| 久久国产99| 欧美一区二区三区四区视频| 亚洲午夜日本在线观看| 日韩一区二区精品| 亚洲激情在线视频| 欧美激情精品久久久六区热门| 久久久女女女女999久久| 欧美一区不卡| 午夜日韩在线观看| 午夜激情综合网| 亚洲女同性videos| 亚洲欧美文学| 午夜久久久久久| 欧美一区二区三区日韩| 欧美亚洲在线| 久久久精彩视频| 久久久免费精品视频| 久久久国产一区二区| 久久久久国产精品www| 久久看片网站| 免费在线亚洲欧美| 亚洲电影在线看| 亚洲日韩欧美视频| 日韩视频在线免费观看| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 欧美日韩一区自拍| 欧美体内she精视频| 国产精品视频成人| 国产一区二区三区四区五区美女| 国产日产亚洲精品系列| 狠狠色综合网站久久久久久久| 久久久无码精品亚洲日韩按摩| 欧美有码在线视频| 久久综合99re88久久爱| 欧美黄色aaaa| 国产精品福利片| 国产日韩欧美精品综合| 在线电影国产精品| 99国产一区| 久久精品动漫| 亚洲第一主播视频| 一本到12不卡视频在线dvd| 午夜精品久久久久久久99樱桃 | 亚洲天堂偷拍| 久久精品国产99国产精品| 欧美 日韩 国产一区二区在线视频 | 99pao成人国产永久免费视频| 中文精品一区二区三区| 久久精品道一区二区三区| 亚洲二区精品| 亚洲欧美日韩国产成人精品影院| 久久精品一区二区三区中文字幕| 一区二区高清在线观看| 欧美一区久久| 欧美日韩国产综合一区二区| 国产日本精品| 日韩网站在线看片你懂的| 久久经典综合| 亚洲精品一区二区三区蜜桃久| 亚洲欧美视频| 欧美精品激情在线| 国外成人在线视频网站| 亚洲亚洲精品在线观看| 免费在线视频一区| 亚洲欧美日韩一区二区在线 | 欧美日韩不卡| 国内久久婷婷综合| 亚洲特黄一级片| 欧美成人午夜视频| 欧美一区成人| 欧美日韩中文在线| 亚洲日本va午夜在线影院| 久久av红桃一区二区小说| 亚洲精品视频在线观看免费| 久久九九99| 国产亚洲成av人片在线观看桃| 99视频精品在线| 欧美电影电视剧在线观看| 午夜日韩激情| 国产精品久久一区主播| 一区二区三区四区精品| 欧美国产精品久久| 久久精品人人爽| 国产人成一区二区三区影院| 亚洲一区二区三区在线播放| 亚洲国产高清自拍| 麻豆精品精品国产自在97香蕉| 国产一区二区三区日韩| 欧美中文字幕视频| 亚洲永久免费av| 国产精品毛片a∨一区二区三区|国| 亚洲精品日日夜夜| 亚洲国产高清视频| 欧美freesex8一10精品| 亚洲国产精品久久久久| 欧美国产成人精品| 乱人伦精品视频在线观看| 在线观看中文字幕亚洲| 另类综合日韩欧美亚洲| 久久久久久夜精品精品免费| 国内精品久久久久国产盗摄免费观看完整版| 亚洲一区影音先锋| 亚洲先锋成人| 国产欧美韩国高清| 久久五月婷婷丁香社区| 久久久久久网站| 亚洲精品久久久久中文字幕欢迎你 | 欧美一区二区三区免费在线看| 亚洲午夜久久久|