• <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>

            Drolca

            Apologize To Drolca
            隨筆 - 28, 文章 - 1, 評(píng)論 - 6, 引用 - 0
            數(shù)據(jù)加載中……

            topcoder學(xué)習(xí)中

            #include <iostream>
            #include 
            <set>
            #include 
            <string>
            #include 
            <queue>
            using namespace std;

            struct state{
                
            long a;
                
            long b;
                
            long c;
                state(
            long i,long j,long k):a(i),b(j),c(k)
                
            {}
            }
            ;
            struct peg{
                state s;
                
            int c;
                peg(state z,
            int cc):s(z),c(cc)
                
            {}
            }
            ;
            bool operator==(const state& a,const state& b){
                
            return a.a==b.a&&a.b==b.b&&a.c==b.c;
            }

            bool operator<(const state& a,const state& b){
                
            if(a.a!=b.a) return a.a<b.a;
                
            if(a.b!=b.b) return a.b<b.b;
                
            return a.c<b.c;
            }


            set<state> vis;

            long conv(const string& a){
                
            long r=0;
                
            for(int i=0;i<a.size();i++){
                    r
            =r*4+(a[i]-'A'+1);
                }

                
            return r;
            }


            class HanoiTower{
            public:
                
            int moves(string pegA,string pegB,string pegC){
                    
            int r=0;
                    queue
            <peg> q;
                    q.push( peg( state( conv(pegA),conv(pegB),conv(pegC) ), 
            0 ) );
                    
            int numA=0,numB=0,numC=0;
                    
            string big=pegA+pegB+pegC;
                    
            for(int i=0;i<big.size();i++){
                        
            if(big[i]=='A') numA++;
                        
            else if(big[i]=='B') numB++;
                        
            else numC++;
                    }

                    
            string tA=string(numA,'A'),tB=string(numB,'B'),tC=string(numC,'C');
                    state target
            =state(conv(tA),conv(tB),conv(tC));
                    
            while(!q.empty()){
                        peg z
            =q.front();q.pop();
                        
            if(z.s==target) return z.c;
                        
            if(vis.count(z.s)!=0continue;
                        vis.insert(z.s);
                        
            long aa=z.s.a;
                        
            long bb=z.s.b;
                        
            long cc=z.s.c;
                        
            if(aa>0){
                            
            int m=aa%4;
                            q.push( peg( state((aa
            -m)/4,bb*4+m,cc),z.c+1));
                            q.push( peg( state((aa
            -m)/4,bb,cc*4+m),z.c+1));
                        }
                    
                        
            if(bb>0){
                            
            int m=bb%4;
                            q.push( peg( state(aa
            *4+m,(bb-m)/4,cc),z.c+1));
                            q.push( peg( state(aa,(bb
            -m)/4,cc*4+m),z.c+1));
                        }
                    
                        
            if(cc>0){
                            
            int m=cc%4;
                            q.push( peg( state(aa,bb
            *4+m,(cc-m)/4),z.c+1) );
                            q.push( peg( state(aa
            *4+m,bb,(cc-m)/4),z.c+1) );
                        }

                    }

                    
            return r;
                }

            }
            ;

            posted on 2009-08-14 12:17 Drolca 閱讀(175) 評(píng)論(1)  編輯 收藏 引用

            評(píng)論

            # re: topcoder學(xué)習(xí)中  回復(fù)  更多評(píng)論   

            ...麻煩了...
            2009-08-14 22:08 | Drolva

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            亚洲综合伊人久久大杳蕉| 久久九九亚洲精品| 伊人久久成人成综合网222| 伊人久久大香线蕉综合热线| 婷婷五月深深久久精品| 久久久国产精品网站| 中文精品久久久久人妻| 成人免费网站久久久| 欧美与黑人午夜性猛交久久久| 久久免费看黄a级毛片| 成人精品一区二区久久| 久久久久久人妻无码| 亚洲日韩欧美一区久久久久我| 久久超乳爆乳中文字幕| 老男人久久青草av高清| 激情综合色综合久久综合| 国内精品九九久久久精品| 怡红院日本一道日本久久 | 狠狠色婷婷综合天天久久丁香 | 九九久久99综合一区二区| 精品久久久久久无码免费| 久久99久久99精品免视看动漫| 亚州日韩精品专区久久久| 成人资源影音先锋久久资源网| 久久久久精品国产亚洲AV无码| 国内精品久久久久国产盗摄| 免费国产99久久久香蕉| 久久久久久久久久久久中文字幕| 无码乱码观看精品久久| 久久夜色精品国产| 久久久久99精品成人片| 国产精品美女久久久网AV| 成人国内精品久久久久影院VR| 久久久噜噜噜久久中文福利| 一本一本久久a久久综合精品蜜桃| 偷窥少妇久久久久久久久| 综合久久给合久久狠狠狠97色| 亚洲国产精品无码久久青草| 午夜精品久久久久久| 久久无码国产专区精品| 一本色综合网久久|