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

我希望你是我獨家記憶

一段永遠封存的記憶,隨風而去
posts - 263, comments - 31, trackbacks - 0, articles - 3
   :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

USACO--414--(ELFHash)

Posted on 2008-07-31 01:16 Hero 閱讀(1489) 評論(4)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM

/*
ID: wangzha4
LANG: C++
TASK: cryptcow
*/

/*
Executing
   Test 1: TEST OK [0.011 secs, 2900 KB]
   Test 2: TEST OK [0.000 secs, 2900 KB]
   Test 3: TEST OK [0.000 secs, 2900 KB]
   Test 4: TEST OK [0.011 secs, 2896 KB]
   Test 5: TEST OK [0.000 secs, 2896 KB]
   Test 6: TEST OK [0.119 secs, 2896 KB]
   Test 7: TEST OK [0.022 secs, 2900 KB]
   Test 8: TEST OK [0.097 secs, 2900 KB]
   Test 9: TEST OK [0.270 secs, 2896 KB]
   Test 10: TEST OK [0.335 secs, 2896 KB]
*/

//這道題目的搜索其實就是類似于深度優先搜索--暴搜
//判斷是否是加密過的過程其實是DFS的過程

//主要在于剪枝( 參考了nocow的講解 )
/*

1. 由于添加的COW是一起的,因此給出的字符串的字符個數應該等于47(目標字符串的長度)+3*k。如果不滿足就可直接判斷無解。 
2. 除了COW三個字符外,其他的字符的個數應該和目標串相一致。如果不一致也可直接判斷無解。
   搜索中間肯定會出現很多相同的情況,因此需要開一個hash來記錄搜索到過哪些字符串,每搜索到一個字符串,就判重。
   如果重復直接剪枝。這里的字符串的hash函數可以采用ELFhash,但由于ELFhash的數值太大,
   所以用函數值對一個大質數(我用的是35023)取余,這樣可以避免hash開得太大,同時又可以減少沖突。 
3. 對搜索到的字符串,設不包含COW的最長前綴為n前綴(同樣也可以定義n后綴),那么如果n前綴不等于目標串的長度相同的前綴,
   那么當前字符串一定無解,剪枝。N后綴也可采取相同的判斷方法。 
4. 一個有解的字符串中,COW三個字母最早出現的應該是C,最后出現的應該是W,如果不滿足則剪枝。 
5 . 當前字符串中任意兩個相鄰的COW字母中間所夾的字符串一定在目標串中出現過。如果不符合可立即剪枝。 
6. 需要優化搜索順序。經過試驗我們可以發現,O的位置對于整個COW至關重要。可以說,O的位置決定了整個串是否會有解。
   因此,我們在搜索時,應該先枚舉O的位置,然后再枚舉C和W的位置。其中W要倒序枚舉。這樣比依次枚舉COW至少要快20~30倍。 
7. 在判斷當前串的子串是否包含在目標串中的時候,可以先做一個預處理:記錄每一個字母曾經出現過的位置,然后可以直接枚舉子串的第一個字母的位置。這樣比用pos要快2倍左右。
*/

#include 
<iostream>
#include 
<string>
#include 
<algorithm>
using namespace std ;
#define llong unsigned long long 
#define unint unsigned int
#define printline  printf( "\n" ) 

const int INF = 1000000 ;
const int size = 155 ;
const int hashsize = 51071 ;

bool hasHashed[hashsize] = { false } ;
const string dest = "Begin the Escape execution at the Break of Dawn" ;
string text ; string trans ;

unsigned 
int ELFHash( string str )
{
    unsigned 
int hash = 0 ;
    unsigned 
int x = 0 ;

    
forint i=0; i<str.length(); i++ ) {
        hash 
= ( hash << 4 ) + ( str[i] ) ;
        
if( ( x = hash & 0xF0000000L ) != 0 ) {
            hash 
^= ( x >> 24 ) ;
            hash 
&= ~x ;
        }
    }

    
return ( hash & 0x7FFFFFFF ) ;
}

bool substr_in_dest( string &sour)
{
//判斷夾在COW之間的字符串是否存在dest中
    forint i=0; i<sour.size(); i++ ) {

        
if( sour[i]=='C' || sour[i]=='O' || sour[i]=='W' )    continue ;

        
int j = i + 1 ;
        
for( j=i+1; j<sour.size(); j++ ) {
            
if'C'==sour[j] || 'O'==sour[j] || 'W'==sour[j] )    break ;
        }
        
if( dest.find( sour.substr( i, j-i ) ) == string::npos )    return false ;

        i 
= j ;
    }

    
return true ;
}

string Transform( string &sour, int c, int o, int w )
{
    trans 
= "" ;
    
forint i=0; i<c; i++ )        trans += sour[i] ;
    
forint i=o+1; i<w; i++ )    trans += sour[i] ;
    
forint i=c+1; i<o; i++ )    trans += sour[i] ;
    
forint i=w+1; i<sour.size(); i++ )    trans += sour[i] ;

    
//trans += '\0' ;//trans != trans + '\0'
    
//cout << trans << endl ;
    return trans ;
}

bool IsEncrypted( string sour )
{
    unsigned 
int hashval = ELFHash( sour ) % hashsize ;
    
if( hasHashed[hashval] )        return false ;
    hasHashed[hashval] 
= true ;

    
if( sour == dest )    return true ;

    
iffalse == substr_in_dest( sour ) )    return false ;

    
forint o=1; o<sour.size(); o++ ) {//枚舉--然后深度優先搜索
        if'O' == sour[o] ) {
            
forint c=0; c<o; c++ ) {
                
if'C' == sour[c] ) {
                    
forint w=sour.size()-1; w>o; w-- ) {
                        
if'W' == sour[w] ) 
                            
if( IsEncrypted( Transform( sour, c, o, w ) ) )    return true ;
                    }
//遞歸判斷是否有一個合理的轉換解,如果有直接return true; 相當于深度優先搜索
                }
            }
        }
    }

    
return false ;
}

int main()
{
    
//freopen( "in.txt", "r", stdin ) ;
    freopen( "cryptcow.in""r", stdin ) ;
    freopen( 
"cryptcow.out","w",stdout ) ;
    
    getline( cin, text ) ;    
//cout << text << endl ;

    
if( ( text.size()-dest.size() ) % 3 != 0 )
    { printf( 
"0 0\n" ) ; return 0 ; }

    
int numc, numo, numw ; numc = numo = numw = 0 ;
    
forint i=0; i<text.size(); i++ ) {
        
if'C' == text[i] )    numc++ ;
        
if'O' == text[i] )    numo++ ;
        
if'W' == text[i] )    numw++ ;
    }
    
if( numc!=numo || numc != numw || numo != numw )    
    { printf( 
"0 0\n" ) ; return 0 ; }

    
if( IsEncrypted( text ) ) {
        cout 
<< "" << count( text.begin(),text.end(),'C' ) << endl ;
    }
    
else {
        printf( 
"0 0\n" ) ;
    }
    
return 0 ;
}

Feedback

# re: USACO--414--(ELFHash)  回復  更多評論   

2009-02-13 21:35 by Ryan Hardy
很厲害

# re: USACO--414--(ELFHash)  回復  更多評論   

2009-03-30 10:33 by tvt
有問題。
Hash完全沒有碰撞處理,而且空間開的很小,最后幾個點有很多串都是實際上未處理完全靠碰撞蒙過去的。
把Hash表開大減小碰撞幾率的話馬上就通不過。
另外如果測試點多幾個正確數據很可能由于正確性而出問題。這是犧牲正確性的投機寫法

# re: USACO--414--(ELFHash)  回復  更多評論   

2010-12-11 23:24 by klion26
@tvt
這個沒處理沖突確實是個問題,不過你說的開大點就過不了,感覺不對.應該是小一點不對.我剛做了這題,數組開的非常大.也用的ELFHash,沒處理沖突,過了[這里最多加密9此],如果數組開小點到時很有可能錯誤,還有如果不加substr_in_dest這個函數的判斷,也會導致沖突.

# re: USACO--414--(ELFHash)  回復  更多評論   

2011-01-27 10:32 by st8676746
tvt確實沒說錯~他的意思是hash開大就會超時。
一旦把hash數組開大后,處理的字符串就會變多(因為你沒處理沖突,所以在hash較小時很多字符串其實被你跳過了)。
我把你的hash開為1000003在第九個數據就超時了~
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日本一区二区三区| 久久九九免费| 国产亚洲精品aa| 国产日韩欧美黄色| 国产视频在线观看一区二区三区| 国产精品毛片| 国产日韩欧美中文在线播放| 国产精品嫩草影院av蜜臀| 国产精品久久综合| 国产无一区二区| 亚洲大胆av| 亚洲乱码精品一二三四区日韩在线 | 美女精品视频一区| 女人香蕉久久**毛片精品| 亚洲国产91| 亚洲精品乱码久久久久久蜜桃麻豆| 99热这里只有精品8| 欧美一区2区视频在线观看| 久久综合电影一区| 欧美另类极品videosbest最新版本| 国产精品国产三级国产普通话99| 国产无遮挡一区二区三区毛片日本| 亚洲第一精品夜夜躁人人爽| 一区二区国产日产| 麻豆国产va免费精品高清在线| 亚洲第一视频网站| 亚欧成人在线| 欧美日韩专区在线| 亚洲国产精品99久久久久久久久| 日韩视频在线一区| 久久狠狠婷婷| 亚洲一区二区精品| 欧美伦理在线观看| 亚洲国产精品久久久久婷婷老年| 亚洲色图综合久久| 猫咪成人在线观看| 午夜久久99| 国产精品国产精品| 夜夜嗨一区二区| 欧美国产欧美亚州国产日韩mv天天看完整| 一区二区三区四区五区精品视频| 久久亚洲春色中文字幕久久久| 国产精品手机视频| 一区二区三区日韩欧美| 亚洲国产精品ⅴa在线观看| 亚洲一级电影| 欧美午夜a级限制福利片| 亚洲精品久久久久久久久久久久| 久久久久久久一区二区三区| 国产精品99久久久久久宅男 | 亚洲福利在线视频| 久久www免费人成看片高清| 国产精品久久激情| 亚洲一级电影| aⅴ色国产欧美| 欧美视频网站| 亚洲一区免费观看| 制服丝袜激情欧洲亚洲| 欧美精品在线免费播放| 亚洲日本va午夜在线电影| 久久久久综合一区二区三区| 性做久久久久久免费观看欧美| 国产精品一区二区久激情瑜伽| 亚洲一区二区三区高清不卡| 日韩亚洲欧美在线观看| 欧美性开放视频| 亚洲欧美中文在线视频| 亚洲一卡二卡三卡四卡五卡| 一区二区三区导航| 久久国产主播精品| 欧美理论大片| 久久久久国产成人精品亚洲午夜| 欧美性大战xxxxx久久久| 一区二区三区.www| 99在线精品视频在线观看| 欧美日韩福利| 亚洲在线视频免费观看| 亚洲欧美中文字幕| 狠狠88综合久久久久综合网| 噜噜噜久久亚洲精品国产品小说| 久久久综合香蕉尹人综合网| 亚洲国产日韩欧美在线99| 亚洲电影下载| 欧美日韩无遮挡| 欧美在线播放高清精品| 久久精品二区| 亚洲全黄一级网站| 一本色道久久88综合日韩精品| 国产美女诱惑一区二区| 久久一区视频| 欧美精品一区二区久久婷婷| 亚洲欧美制服另类日韩| 久久精品最新地址| 一区二区欧美国产| 久久精品国产第一区二区三区最新章节 | 亚洲高清在线观看| 欧美日韩视频在线一区二区观看视频| 欧美在线播放高清精品| 六月丁香综合| 欧美伊人精品成人久久综合97| 久久在线视频在线| 亚洲综合色视频| 麻豆精品视频在线观看| 午夜久久影院| 欧美日本不卡| 巨乳诱惑日韩免费av| 欧美天堂在线观看| 美腿丝袜亚洲色图| 国产精品自在在线| 日韩天堂在线观看| 亚洲高清激情| 性欧美18~19sex高清播放| 亚洲经典三级| 久久国产视频网站| 亚洲欧美综合另类中字| 欧美成人黄色小视频| 久久久久久久久岛国免费| 国产精品久久久久久影视 | 亚洲国产另类久久久精品极度| 一本久久a久久精品亚洲| 亚洲黄网站在线观看| 性色一区二区| 欧美资源在线| 国产精品丝袜xxxxxxx| 一区二区三区鲁丝不卡| 亚洲裸体在线观看| 欧美激情一区二区三区不卡| 亚洲在线观看视频网站| 国产精自产拍久久久久久| 亚洲国产精品精华液网站| 国产一区二区三区最好精华液| 99re国产精品| 一本色道久久精品| 欧美巨乳在线| 欧美成人午夜视频| 在线观看日产精品| 另类天堂av| 欧美福利电影网| 亚洲激情校园春色| 欧美国产日本在线| 亚洲人www| 亚洲天堂激情| 国产精品日韩精品欧美在线 | 久久久福利视频| 国产午夜精品麻豆| 久久久久一区二区三区四区| 久久久午夜精品| 一区二区三区在线视频观看| 久久国产精品亚洲77777| 久久久久国产一区二区| 国产最新精品精品你懂的| 欧美在线亚洲| 欧美国产另类| 亚洲韩国精品一区| 欧美精品一区二区三区在线看午夜 | 一区二区三区三区在线| 欧美日韩亚洲系列| 亚洲欧美日韩另类精品一区二区三区| 先锋影院在线亚洲| 国模大胆一区二区三区| 久久久伊人欧美| 亚洲黄色影院| 亚洲视频你懂的| 国产日韩精品入口| 欧美成人午夜激情视频| 一本色道**综合亚洲精品蜜桃冫| 久久激情视频久久| 亚洲国产精品999| 国产精品扒开腿爽爽爽视频| 午夜精品福利视频| 亚洲风情亚aⅴ在线发布| 一本色道久久88精品综合| 国产精品午夜在线| 麻豆亚洲精品| 亚洲午夜一级| 欧美激情在线观看| 欧美一区二区视频97| 亚洲激情一区| 国产欧美日韩91| 欧美**人妖| 中文在线一区| 亚洲激情欧美激情| 久久色中文字幕| 国产精品99久久久久久白浆小说| 国产综合香蕉五月婷在线| 欧美另类人妖| 久热精品在线| 欧美一级艳片视频免费观看| 亚洲国产二区| 麻豆91精品| 久久久福利视频| 亚洲一区二区三区在线| 亚洲国产精品悠悠久久琪琪| 欧美绝品在线观看成人午夜影视| 亚洲激情在线观看视频免费| 宅男精品视频| 亚洲精品孕妇| 在线观看欧美激情| 国产亚洲精品久久久久久| 国产精品爱久久久久久久|