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

隨筆-72  評論-126  文章-0  trackbacks-0
再來一道簡單點的。。。這道用鄰接表+hash就OK了
http://acm.hdu.edu.cn/showproblem.php?pid=1524

神奇的圖博弈
http://acm.hdu.edu.cn/showproblem.php?pid=1809
根據遞歸求出沒副圖的sg值,然后異或
但是如果暴力遞歸的話會做很多重復的搜索
所以hash一下用記憶化搜索
要整個地圖的狀態來hash
我搞了半天搞不定
后來查到神奇的字符hash方法
用了一下果然很靈
不過現在還是不太清楚為什么這樣可以hash
// RS Hash Function
unsigned int RSHash(char* str)
{
    unsigned 
int b = 378551 ;
    unsigned 
int a = 63689 ;
    unsigned 
int hash = 0 ;
    
while (*str)
    {
        hash 
= hash * a + (*str ++ );
        a 
*= b;
    }
    
return (hash & 0x7FFFFFFF );
}

// JS Hash Function
unsigned int JSHash(char* str)
{
    unsigned 
int hash = 1315423911 ;
    
while (*str)
    {
        hash 
^= ((hash << 5 ) + (*str ++ ) + (hash >> 2 ));
    }
    
return (hash & 0x7FFFFFFF );
}

// P. J. Weinberger Hash Function
unsigned int PJWHash(char* str)
{
    unsigned 
int BitsInUnignedInt = (unsigned int )( sizeof (unsigned int)*8 );
    unsigned 
int ThreeQuarters = (unsigned int )((BitsInUnignedInt*3 ) / 4 );
    unsigned 
int OneEighth = (unsigned int )(BitsInUnignedInt / 8 );
    unsigned 
int HighBits = (unsigned int )( 0xFFFFFFFF ) << (BitsInUnignedInt - OneEighth);
    unsigned 
int hash = 0 ;
    unsigned 
int test = 0 ;
    
while (*str)
    {
        hash 
= (hash << OneEighth) + (*str ++ );
        
if ((test = hash & HighBits) != 0 ) {
            hash 
= ((hash ^ (test >> ThreeQuarters)) & ( ~ HighBits));
        }
    }
    
return (hash & 0x7FFFFFFF );
}

// ELF Hash Function
unsigned int ELFHash(char* str)
{
    unsigned 
int hash = 0 ;
    unsigned 
int x = 0 ;    while (*str)
    {
        hash 
= (hash << 4 ) + (*str ++ );
        
if ((x = hash & 0xF0000000L ) != 0 ) {
            hash 
^= (x >> 24 );
            hash 
&= ~ x;
        }
    }
    
return (hash & 0x7FFFFFFF );
}

// BKDR Hash Function
unsigned int BKDRHash(char* str)
{
    unsigned 
int seed = 131 ; // 31 131 1313 13131 131313 etc..
    unsigned int hash = 0 ;
    
while (*str)
    {
        hash 
= hash*seed + (*str ++ );
    }
    
return (hash & 0x7FFFFFFF );
}

// SDBM Hash Function
unsigned int SDBMHash(char* str)
{
    unsigned 
int hash = 0 ;
    
while (*str)
    {
        hash 
= (*str ++ ) + (hash << 6 ) + (hash << 16 ) - hash;
    }
    
return (hash & 0x7FFFFFFF );
}

// DJB Hash Function
unsigned int DJBHash(char* str)
{
    unsigned 
int hash = 5381 ;
    
while (*str)
    {
        hash 
+= (hash << 5 ) + (*str ++ );
    }
    
return (hash & 0x7FFFFFFF );
}

// AP Hash Function
unsigned int APHash(char* str)
{
    unsigned 
int hash = 0 ;
    
int i;
    
for (i = 0 ;*str; i ++ )
    {
        
if ((i & 1 ) == 0 )    {
            hash 
^= ((hash << 7 ) ^ (*str ++ ) ^ (hash >> 3 ));
        }    
else {
            hash 
^= ( ~ ((hash << 11 ) ^ (*str ++ ) ^ (hash >> 5 )));
        }
    }
    
return (hash & 0x7FFFFFFF );
}
posted on 2009-03-01 06:13 shǎ崽 閱讀(322) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品第一区| 久久久久久网站| 国产精品久久久久久久9999| 亚洲一级网站| 99re6这里只有精品视频在线观看| 久久久久久久久久久久久9999| 亚洲欧美日韩国产综合| 久久九九精品99国产精品| 一本色道久久综合亚洲精品不| 噜噜噜91成人网| 欧美成人免费大片| 91久久精品国产91久久性色| 狂野欧美一区| 欧美日韩福利视频| 国产欧美一区在线| 91久久久精品| 宅男噜噜噜66一区二区| 一本色道综合亚洲| 久久九九全国免费精品观看| 欧美www视频在线观看| 99re热精品| 久久青青草原一区二区| 欧美人与性禽动交情品 | 亚洲永久免费观看| 久久久九九九九| 一区二区黄色| 欧美日韩国产免费观看| 精久久久久久| 亚洲一区二区在线视频| 亚洲第一中文字幕| 性欧美超级视频| 国产精品夜夜夜| 亚洲一区不卡| 亚洲九九九在线观看| 久久天天狠狠| 亚洲大片av| 麻豆av福利av久久av| 欧美一区二区三区四区夜夜大片| 欧美国产精品一区| 亚洲网站在线看| 国产精品久久久亚洲一区| 在线一区视频| 亚洲尤物影院| 国内精品写真在线观看| 久久久国际精品| 久久久亚洲人| 日韩天堂在线观看| 亚洲少妇在线| 国产一区二区三区四区| 亚洲电影在线观看| 欧美日韩亚洲一区三区| 中文av字幕一区| 亚洲欧美三级在线| 亚洲激情影院| 亚洲图片在区色| 一区二区视频免费完整版观看| 免费不卡中文字幕视频| 欧美巨乳在线| 久久综合九色九九| 欧美日韩在线直播| 久久一区二区三区超碰国产精品| 欧美成人午夜激情视频| 亚洲欧美另类中文字幕| 蜜桃av一区二区在线观看| 亚洲淫片在线视频| 欧美1区2区| 久久久免费av| 国产精品美女诱惑| 亚洲精品一区在线观看香蕉| 一色屋精品视频在线观看网站| 亚洲美女毛片| 亚洲免费高清| 欧美精品日韩一区| 女仆av观看一区| 在线观看国产一区二区| 久久激情视频| 国产精品日韩| 欧美亚洲视频在线观看| 亚洲欧美日韩精品| 国产精品免费一区二区三区在线观看| 亚洲国产精品ⅴa在线观看 | 久久理论片午夜琪琪电影网| 欧美一区二区三区视频在线观看| 欧美体内谢she精2性欧美| 最新成人在线| 午夜精品免费视频| 国产区精品在线观看| 久久国产精品99精品国产| 久久久欧美精品| 亚洲精品一区二区三区av| 欧美日韩亚洲一区三区 | 国产欧美日韩伦理| 欧美一级视频| 亚洲日韩欧美视频一区| 亚洲免费伊人电影在线观看av| 国产精品男gay被猛男狂揉视频| 久久精品亚洲一区二区| 亚洲欧洲综合另类| 欧美在线在线| 中文成人激情娱乐网| 亚洲第一色在线| 国产欧美婷婷中文| 欧美日本不卡| 欧美va亚洲va香蕉在线| 亚洲欧美视频在线观看| 一本久道久久综合狠狠爱| 麻豆精品视频在线| 久久九九电影| 久久av一区二区三区漫画| 99视频精品全部免费在线| 亚洲无线一线二线三线区别av| 免费观看国产成人| 欧美在线免费| 欧美一区二区三区四区夜夜大片| 亚洲精品美女在线观看播放| 影音先锋中文字幕一区二区| 国产欧美日本一区二区三区| 欧美视频在线不卡| 欧美日韩高清在线播放| 欧美连裤袜在线视频| 欧美日韩国产丝袜另类| 欧美国产日韩一区二区三区| 暖暖成人免费视频| 欧美精品自拍| 国产精品推荐精品| 国产视频一区在线观看一区免费 | 一本大道久久a久久综合婷婷| 亚洲国产91精品在线观看| 欧美激情在线狂野欧美精品| 亚洲黄色在线| 午夜精品久久| 免费在线看一区| 国产精品美女久久久久av超清 | 欧美极品一区| 国产欧美在线视频| 在线看成人片| 亚洲性人人天天夜夜摸| 久久国产精品电影| 亚洲精品久久久蜜桃 | 久久精品国产精品| 嫩草成人www欧美| 亚洲一区二区影院| 美女国内精品自产拍在线播放| 国产精品蜜臀在线观看| 亚洲美女电影在线| 欧美国产日韩a欧美在线观看| 一区二区三区四区精品| 麻豆国产精品777777在线| 亚洲一区二区三区成人在线视频精品| 久久国产精品久久精品国产| 国产精品普通话对白| 一本色道精品久久一区二区三区 | 久久久久久久精| 国产精品99久久99久久久二8| 欧美激情中文字幕乱码免费| 亚洲国产一区二区在线| 免费欧美电影| 欧美日本不卡高清| 亚洲性图久久| 亚洲综合欧美| 激情亚洲成人| 亚洲高清免费视频| 欧美1区视频| 亚洲乱码国产乱码精品精天堂| 久久综合中文字幕| 欧美专区中文字幕| 亚洲精品国产精品国自产观看浪潮| 欧美一区二区精品在线| 亚洲一区二区三区午夜| 韩日午夜在线资源一区二区| 久久精品色图| 美日韩精品视频| 国产欧美精品xxxx另类| 欧美永久精品| 久久人人爽国产| 欧美天堂亚洲电影院在线观看| 午夜精品免费在线| 久久成人精品视频| 亚洲国产精品综合| 欧美在线欧美在线| 影音先锋亚洲一区| 亚洲精品一区二区三区樱花| 在线观看欧美日韩| 亚洲精品久久久久久久久久久久久 | 国产自产精品| 欧美成人首页| 你懂的一区二区| 欧美日韩日本网| 久久婷婷蜜乳一本欲蜜臀| 欧美小视频在线| 麻豆av一区二区三区久久| 欧美日韩视频一区二区三区| 亚洲电影欧美电影有声小说| 国产亚洲精品久久久久动| 亚洲精品国产品国语在线app | 亚洲三级视频| 在线观看视频欧美| 午夜欧美大尺度福利影院在线看| 中文精品视频| 欧美日韩综合|