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

gzwzm06

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  1 隨筆 :: 52 文章 :: 17 評論 :: 0 Trackbacks
Trie + 并查集
#include <stdio.h>
#include 
<cstring>

const int MAXN = 600002 ;

int father[MAXN] ;
int degree[MAXN] ;
int N ;

int FindSet( int x )
{
    
int t , y ;
    t 
= father[x] ;
    y 
= x ;
    
while ( t != father[t] ) t = father[t] ;
    
while ( x != t )
    
{
        y 
= father[x] ;
        father[x] 
= t ;
        x 
= y ;
    }


    
return t ;
}


void UnionSet( int x, int y )
{
    
int u = FindSet(x) ;
    
int v = FindSet(y) ;

    father[v] 
= u ;
}


const int CAP = 26 ;
typedef 
struct NODE
{    
    NODE()
    
{
        cnt 
= 0;
        id 
= 0;
        memset(next, NULL, 
sizeof(NODE));
    }
;
    NODE 
*next[CAP];
    
int cnt;
    
int id;
}
NODE;

const int MEMORY = 600001 ;//節點數目
NODE memory[MEMORY] ;
class BTree
{
public:
    BTree()
    
{
        index 
= 1;
        id_index 
= 0;
        head 
= &memory[0];
    }


    
//插入單詞(返回單詞ID)
    int insert(char *str)
    
{
        
int len = (int)strlen(str);
        NODE 
*pt = head;
        
for (int i = 0; i < len; ++i)
        
{
            
if (pt->next[str[i]-'a'== NULL)
            
{
                pt
->next[str[i]-'a'= &memory[index++];
            }

            
            pt 
= pt->next[str[i]-'a'];
        }


        
if (pt->cnt == 0)
            pt
->id = id_index++;

        (pt
->cnt)++;//單詞累加一
        
        
return pt->id;
    }


public:
    NODE 
*head;
    
int index;//內存索引
    int id_index;//單詞ID索引
}
;

void Init()
{
    
int i ;

    
for ( i = 0 ; i < MAXN ; i++ )
    
{
        father[i] 
= i ;
        degree[i] 
= 0 ;
    }

}


int main()
{
    
char str1[12], str2[12] ;
    BTree trie ;
    
int x , y , num , i ;
    Init() ;
//    freopen("1.txt", "r", stdin) ;

    
while ( scanf("%s %s"&str1, &str2) != EOF )
    
{
        x 
= trie.insert( str1 ) ;
        y 
= trie.insert( str2 ) ;
        degree[x]
++ ;
        degree[y]
++ ;

        UnionSet( x, y ) ;
    }


    num 
= trie.id_index ;
    
bool con = true ;

    
if ( num == 0 ){
        printf(
"Possible\n") ;
    }

    
else {
        
        x 
= FindSet( 0 ) ;
        
        
for ( i = 1 ; i < num ; i++ )
        
{
            y 
= FindSet( i ) ;
            
if ( x != y )
            
{
                con 
= false ;
                
break ;
            }

        }


        
if ( !con )
        
{
            printf(
"Impossible\n") ;
        }

        
else{
            x 
= 0 ;
            
for ( i = 0 ; i < num ; i++ )
            
{
                
if ( degree[i] % 2 != 0 )
                    x
++ ;
            }


            
if ( x == 2 || x == 0 )
            
{
                printf(
"Possible\n") ;
            }

            
else{
                printf(
"Impossible\n") ;
            }

        }

    }



    
return 0 ;
}
posted on 2008-11-08 15:50 閱讀(449) 評論(2)  編輯 收藏 引用 所屬分類: 字符串處理

評論

# re: Pku 2513--Colored Sticks(Trie) 2009-02-11 17:20 LC
請問一下
pt->next[str[i]-'a'] = &memory[index++];

memory是用來保存什么啊
這句什么意思啊?
本人不太熟練指針有望指教??!  回復  更多評論
  

# re: Pku 2513--Colored Sticks(Trie)[未登錄] 2009-08-21 15:42 tom
memory 就一數組啊  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美成人一区二区三区| 一本色道久久加勒比精品| 久久精品成人欧美大片古装| 亚洲福利视频网| 久久久综合视频| 欧美一区二区三区日韩视频| 亚洲欧美bt| 久久久午夜视频| 欧美不卡在线视频| 亚洲二区在线观看| 亚洲精品欧美一区二区三区| 99pao成人国产永久免费视频| 亚洲久久成人| 亚洲欧美日韩专区| 欧美aaa级| 国产精品伦一区| 亚洲国产精品一区二区三区| 一本色道久久精品| 久久久久99| 一区二区三区你懂的| 欧美在线3区| 欧美日韩mp4| 国内精品视频久久| 亚洲素人一区二区| 最新精品在线| 久久久999成人| 国产亚洲欧美在线| 久久国产精品久久国产精品| 欧美成人在线免费观看| 亚洲一区区二区| 欧美一区影院| 亚洲一区二区三区免费视频| 久久亚洲国产精品一区二区| 国产一区二区三区av电影| 亚洲视频一区| 亚洲二区在线视频| 女同一区二区| 亚洲久久一区| 亚洲精品欧美在线| 欧美日韩精品二区| av不卡在线看| 亚洲视频一区在线| 国产亚洲成av人在线观看导航| 亚洲视频第一页| 午夜精品在线视频| 亚洲第一黄网| 一区二区三区不卡视频在线观看 | 国产精品网站在线观看| 亚洲午夜久久久| 欧美亚洲在线观看| 亚洲精品一二三| 亚洲欧美日韩国产综合| 亚洲国产高清在线| 99精品国产在热久久| 国产一区二区三区四区老人| 亚洲福利视频三区| 影音先锋久久久| 亚洲一区二区三区欧美| 亚洲美女黄色片| 久久精品国产综合精品| 亚洲午夜羞羞片| 美日韩精品视频免费看| 欧美一区91| 亚洲美女免费精品视频在线观看| 国产精品电影网站| 欧美v亚洲v综合ⅴ国产v| 国产欧美精品| 一区二区三区视频在线播放| 亚洲国产高清在线观看视频| 久久av二区| 久久精品伊人| 国产一区二区无遮挡| 亚洲夜间福利| 先锋影音网一区二区| 美女在线一区二区| 亚洲欧洲一二三| 99在线观看免费视频精品观看| 美日韩免费视频| 亚洲高清电影| 亚洲一区精品在线| 国产精品久久夜| 亚洲欧美成aⅴ人在线观看| 先锋亚洲精品| 亚洲日本成人网| 欧美日韩国产高清视频| 亚洲性夜色噜噜噜7777| 久久天天躁狠狠躁夜夜爽蜜月| 精品二区久久| 欧美日韩天天操| 久久国产精品一区二区三区| 欧美激情精品久久久六区热门| 亚洲视频一区二区在线观看| 国产精品久久一级| 欧美精品123区| 欧美在线黄色| 日韩特黄影片| 免费视频久久| 久久国产精品亚洲77777| 亚洲精品之草原avav久久| 国产精品久久福利| 欧美成在线观看| 裸体歌舞表演一区二区| 欧美在线播放一区| 99国产一区| 1024精品一区二区三区| 国产欧美高清| 国产亚洲精品久| 国产女同一区二区| 国产伦理精品不卡| 国产午夜精品一区理论片飘花| 欧美另类在线观看| 欧美国产亚洲视频| 欧美激情导航| 欧美高清视频免费观看| 欧美高清视频一区| 欧美大片在线看| 国产精品久久久一区二区三区| 欧美视频一区二区在线观看 | 一区二区三区精品久久久| 欧美大片一区二区| 亚洲精品国产无天堂网2021| 欧美高清不卡在线| 一本色道久久综合狠狠躁篇怎么玩 | 久久精品国产69国产精品亚洲| 午夜激情亚洲| 欧美黑人一区二区三区| 欧美日韩中文| 黄色小说综合网站| 亚洲国产视频a| 亚洲免费一区二区| 另类av一区二区| 一区二区欧美国产| 裸体丰满少妇做受久久99精品| 欧美日韩中文字幕综合视频| 国产主播一区二区| 99在线|亚洲一区二区| 欧美在线中文字幕| 一区二区三区.www| 嫩草国产精品入口| 久久aⅴ国产紧身牛仔裤| 欧美日韩亚洲一区三区| 一区二区三区无毛| 久久aⅴ国产欧美74aaa| 亚洲久色影视| 欧美日韩亚洲激情| 亚洲精品视频二区| 男女av一区三区二区色多| 亚洲网站啪啪| 国产欧美精品日韩精品| 亚洲摸下面视频| 亚洲在线一区二区| 国产精品白丝jk黑袜喷水| 99精品国产一区二区青青牛奶| 美女主播视频一区| 免费亚洲婷婷| 99国产精品| 在线亚洲自拍| 国产亚洲精品一区二区| 欧美在线影院| 欧美大尺度在线| 亚洲精品亚洲人成人网| 一本色道久久88亚洲综合88| 国产日本亚洲高清| 亚洲国产成人av| 国产精品久久福利| 免费在线观看日韩欧美| 欧美人与性禽动交情品 | 午夜精品久久久久久久久久久久| 99精品免费网| 一区二区三区在线免费观看| 欧美成人午夜免费视在线看片| 美女被久久久| 亚洲欧美日本视频在线观看| 欧美在线国产精品| 亚洲视频综合| 嫩草国产精品入口| 久久精品二区三区| 欧美日韩直播| 亚洲精品男同| 99国产精品私拍| 久久久久综合一区二区三区| 欧美日韩精品伦理作品在线免费观看| 亚洲一区二区欧美日韩| 久久久久久尹人网香蕉| 欧美一区二区三区另类| 欧美精品一区在线| 免费久久99精品国产自在现线| 国产农村妇女精品| 亚洲午夜电影在线观看| 亚洲亚洲精品在线观看 | 欧美18av| 亚洲国产精品999| 日韩视频一区二区在线观看| 久久久久久高潮国产精品视| 久久精品国产亚洲5555| 国内自拍视频一区二区三区 | 午夜久久一区| 久久高清福利视频| 一区在线观看| 欧美特黄视频|