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

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 閱讀(450) 評論(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>
            欧美在线观看你懂的| 久久资源av| 亚洲午夜电影网| 欧美色精品天天在线观看视频| 一区二区三区国产| 在线亚洲欧美专区二区| 国产精品理论片| 久久久久久久久久久一区| 久久国产精品99国产精| 在线播放日韩欧美| 91久久综合亚洲鲁鲁五月天| 欧美女人交a| 亚洲一区二区三区三| 亚洲欧美在线视频观看| 永久久久久久| 亚洲精品国产精品久久清纯直播| 欧美日韩一级黄| 久久精品国产一区二区电影| 久久久伊人欧美| 一本色道久久综合狠狠躁篇的优点 | 欧美视频一区二区在线观看| 亚洲一二三区在线观看| 亚洲欧美日韩在线综合| 亚洲国产精品成人va在线观看| 亚洲国产一区视频| 国产精品色午夜在线观看| 欧美 日韩 国产精品免费观看| 欧美精品一区二区三区视频 | 国产午夜精品一区二区三区欧美| 久久久久综合网| 欧美精品1区2区3区| 欧美一级片久久久久久久| 久久一二三四| 亚洲欧美在线x视频| 久热精品视频在线观看| 亚洲女人小视频在线观看| 久久亚洲捆绑美女| 亚洲免费一区二区| 蜜臀av在线播放一区二区三区| 亚洲欧美www| 欧美xx视频| 久久久亚洲人| 欧美性片在线观看| 亚洲高清影视| 国内精品伊人久久久久av一坑| 亚洲精品中文字| 亚洲高清免费| 欧美自拍偷拍午夜视频| 亚洲一区在线直播| 欧美日本在线观看| 免费欧美在线视频| 国产一区二区三区四区老人| 在线亚洲观看| 亚洲午夜精品网| 欧美精品乱码久久久久久按摩| 六月婷婷一区| 国产一区二区在线免费观看 | 欧美.www| 韩国成人福利片在线播放| 中文一区在线| 亚洲午夜激情免费视频| 欧美激情中文字幕一区二区 | 一区二区三区色| 欧美成年人在线观看| 欧美a级大片| 激情成人综合网| 欧美一区二区视频在线观看2020| 亚洲欧美在线免费| 欧美亚州韩日在线看免费版国语版| 亚洲精品乱码久久久久久久久| 亚洲片国产一区一级在线观看| 久久综合成人精品亚洲另类欧美| 开心色5月久久精品| 极品av少妇一区二区| 久久精品国产久精国产思思| 久久久久久香蕉网| 激情亚洲网站| 狂野欧美激情性xxxx| 欧美激情1区| 99国产精品久久久久老师| 欧美另类高清视频在线| 日韩视频一区二区在线观看 | 国产精品永久入口久久久| 国产精品99久久久久久久vr| 亚洲欧美日韩一区在线观看| 国产精品一区毛片| 欧美中文字幕第一页| 欧美成人黑人xx视频免费观看| 亚洲激情女人| 欧美视频在线不卡| 亚洲免费在线看| 免费亚洲婷婷| 一本色道久久88综合亚洲精品ⅰ| 国产精品乱码妇女bbbb| 欧美影院在线| 亚洲人成亚洲人成在线观看| 亚洲中字在线| 在线成人欧美| 欧美视频在线观看视频极品| 亚洲欧美日韩中文在线制服| 欧美成人首页| 亚洲一区视频在线| 黄色日韩在线| 欧美日韩精品免费 | 久久视频在线看| 亚洲精品日韩在线观看| 国产精品久久久一区二区| 久久久欧美精品| 一个人看的www久久| 久久亚洲美女| 亚洲午夜激情免费视频| 原创国产精品91| 欧美三级欧美一级| 久久久综合网站| 中文一区二区| 亚洲国产精品一区二区三区| 欧美在线观看视频一区二区| 亚洲乱码日产精品bd| 国产一区二区三区在线观看免费视频| 欧美va天堂| 久久久91精品国产一区二区三区| 亚洲精品一级| 欧美成人精品| 久久久久在线观看| 亚洲欧美日韩另类精品一区二区三区 | 中国成人在线视频| 欧美电影在线| 久久精品国产一区二区三区| 亚洲一区二区三区在线| 亚洲欧洲精品一区| 在线成人av网站| 国产区精品视频| 国产精品久久久久久久久免费桃花| 欧美aa国产视频| 久久综合久久久久88| 午夜精品久久久久久久99热浪潮| 亚洲精品久久久久| 欧美激情国产高清| 免费成人高清| 欧美99在线视频观看| 久久久精品免费视频| 久久本道综合色狠狠五月| 亚洲综合色激情五月| 一区二区三区视频观看| av成人免费在线观看| 亚洲免费观看高清在线观看 | 亚洲永久免费观看| 亚洲少妇诱惑| 国产精品99久久久久久久久久久久 | 国产热re99久久6国产精品| 国产精品二区在线| 国产精品海角社区在线观看| 欧美日韩视频不卡| 国产精品v日韩精品| 国产精品地址| 国产精品一区二区在线观看网站| 国产精品视频久久一区| 国产精品永久| 国产又爽又黄的激情精品视频 | 欧美激情精品久久久久久| 免费永久网站黄欧美| 欧美国产一区二区三区激情无套| 欧美国产欧美综合 | 美日韩精品免费观看视频| 老牛影视一区二区三区| 欧美国产精品人人做人人爱| 欧美理论电影网| 国产精品激情偷乱一区二区∴| 国产精品有限公司| 精品91在线| 亚洲伦伦在线| 性久久久久久| 免费美女久久99| 日韩亚洲视频在线| 亚洲欧美在线看| 久久综合给合| 欧美性视频网站| 国内精品久久久久久 | 亚洲国产一区二区三区在线播| 日韩亚洲精品视频| 欧美在线观看网站| 亚洲国产成人不卡| 亚洲一区综合| 欧美 日韩 国产在线| 欧美视频在线看| 在线成人性视频| 亚洲午夜在线观看| 欧美+日本+国产+在线a∨观看| 亚洲美女电影在线| 久久久精品久久久久| 欧美日韩在线视频一区二区| 红桃视频亚洲| 亚洲欧洲av一区二区三区久久| 美玉足脚交一区二区三区图片| 亚洲久久在线| 麻豆精品视频在线观看视频| 国产精品日日摸夜夜摸av| 亚洲美女av电影| 久久婷婷国产综合精品青草| 一区二区日韩欧美|