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

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>
            国产视频在线观看一区二区三区| 麻豆乱码国产一区二区三区| 亚洲手机成人高清视频| 99精品视频免费观看| 亚洲精品九九| 亚洲三级色网| 日韩视频中文字幕| 一区二区三区三区在线| 亚洲图片欧洲图片av| 亚洲一区在线观看免费观看电影高清| 中文av字幕一区| 亚洲欧美日本国产有色| 午夜久久久久| 久久久国际精品| 美女精品一区| 欧美另类在线播放| 国产精品vvv| 国产亚洲成精品久久| 精品成人一区二区三区四区| 亚洲第一页中文字幕| 日韩西西人体444www| 亚洲一区观看| 久久精品一区四区| 欧美成人综合一区| 亚洲精品久久久久久久久久久久久| 9色精品在线| 性亚洲最疯狂xxxx高清| 美女尤物久久精品| 欧美午夜精品久久久久久超碰| 国产精品午夜久久| 尤妮丝一区二区裸体视频| 亚洲精品一二三| 欧美伊人久久久久久午夜久久久久| 久久综合精品国产一区二区三区| 亚洲大片免费看| 亚洲先锋成人| 久久久在线视频| 欧美日韩网站| 好吊视频一区二区三区四区 | 亚洲天堂网在线观看| 欧美一区二区三区在线| 欧美成人高清| 国产精品一区在线播放| 亚洲福利视频免费观看| 亚洲一区二区不卡免费| 久久综合九九| 中文在线一区| 免费高清在线一区| 国产精品自拍小视频| 亚洲国产欧美精品| 欧美一区1区三区3区公司| 亚洲电影观看| 欧美一区午夜精品| 欧美日韩一区二区在线播放| 黑人一区二区| 亚洲一区二区三区午夜| 久久国产精品一区二区三区四区| 欧美国产日本在线| 亚洲欧美三级在线| 欧美日本韩国| 亚洲第一主播视频| 午夜精品久久久久久久白皮肤| 欧美福利视频一区| 欧美一区二区高清在线观看| 欧美久久影院| 亚洲国产视频一区二区| 欧美专区中文字幕| aa级大片欧美三级| 欧美成人免费在线观看| 国产一区二区三区免费在线观看| 亚洲视频在线免费观看| 欧美激情国产精品| 久久精品国产999大香线蕉| 欧美性开放视频| 日韩一级免费| 欧美高清在线视频观看不卡| 久久成人免费视频| 国产欧美精品xxxx另类| 亚洲摸下面视频| 亚洲卡通欧美制服中文| 欧美大片在线看免费观看| 激情欧美一区二区三区| 久久大逼视频| 亚洲免费在线观看| 欧美系列精品| 亚洲视频高清| 亚洲伦理在线观看| 欧美精品一区二区三区在线看午夜| 亚洲成色精品| 美女爽到呻吟久久久久| 久久精品国产在热久久| 国产丝袜美腿一区二区三区| 亚洲永久字幕| 一级日韩一区在线观看| 欧美—级a级欧美特级ar全黄| 亚洲国产欧美一区二区三区同亚洲| 快射av在线播放一区| 欧美一级电影久久| 国产日韩一区二区三区在线| 欧美一区综合| 欧美中文字幕第一页| 国产一区二区三区直播精品电影 | 欧美成人免费网| 亚洲欧洲日本专区| 亚洲第一在线综合在线| 久热精品在线| 亚洲精品小视频| 亚洲毛片播放| 欧美性猛交xxxx乱大交蜜桃| 亚洲一区二区三区国产| 亚洲一区高清| 国产视频亚洲精品| 久久午夜精品一区二区| 久久亚洲高清| 亚洲精品免费网站| 亚洲每日在线| 国产精品久久久久久av下载红粉| 午夜精品短视频| 校园春色国产精品| 在线观看中文字幕亚洲| 亚洲第一在线综合在线| 欧美日韩免费一区二区三区| 亚洲欧美日本国产专区一区| 午夜亚洲福利在线老司机| 国产一区二区黄| 亚洲国产中文字幕在线观看| 女女同性精品视频| 国产精品久久久对白| 国产欧美激情| avtt综合网| 亚洲九九精品| 久久精品女人天堂| 久久精品国产免费看久久精品| 免费观看在线综合| 欧美一级免费视频| 欧美成人精品一区二区| 午夜精品福利一区二区蜜股av| 午夜亚洲福利在线老司机| 亚洲成人在线观看视频| 日韩一级裸体免费视频| 亚洲国产天堂久久综合网| 久久国产精品色婷婷| 欧美伊人影院| 国产亚洲精品久久久| 亚洲伊人第一页| 欧美一区二区免费观在线| 国产在线观看精品一区二区三区 | 亚洲欧美在线免费| 欧美一区二区三区在线观看| 亚洲日本中文字幕区| 亚洲一区网站| 亚洲精品国产精品久久清纯直播| 夜夜精品视频一区二区| 黄色影院成人| 亚洲视频免费在线| 亚洲国产精品va在线看黑人| 亚洲视频一二| 亚洲精品在线电影| 亚洲综合久久久久| 亚洲精品你懂的| 欧美资源在线| 亚洲夜间福利| 美女精品一区| 久久久久**毛片大全| 欧美深夜影院| 欧美国产精品人人做人人爱| 国产女主播在线一区二区| 最新中文字幕亚洲| 国产午夜精品久久久久久久| 亚洲精品日韩在线| 怡红院精品视频| 亚洲欧美日韩系列| 一区二区三区精密机械公司 | 中文亚洲免费| 亚洲精品一区二区在线| 久久国产精品72免费观看| 亚洲专区欧美专区| 欧美成人黑人xx视频免费观看| 久久精品国产久精国产爱| 国产精品国产三级国产aⅴ浪潮| 亚洲国产精品一区二区www在线| 国内久久婷婷综合| 亚洲欧美日韩一区二区| 亚洲一区二区黄| 欧美日韩的一区二区| 欧美黑人一区二区三区| 韩国成人精品a∨在线观看| 亚洲欧美日韩精品| 亚洲欧美日本在线| 欧美系列精品| 一区二区三区欧美| 一区二区三区蜜桃网| 欧美精品国产精品日韩精品| 欧美激情按摩| 亚洲第一网站| 久久性天堂网| 欧美电影打屁股sp| 亚洲国产美女精品久久久久∴| 久久精品一区中文字幕| 久久香蕉国产线看观看av|