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

            misschuer

            常用鏈接

            統計

            積分與排名

            百事通

            最新評論

            hdu 1195 Open the Lock

            http://acm.hdu.edu.cn/showproblem.php?pid=1195

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

            struct root
            {
                
            char data[ 5 ];
                
                
            int step;
            }
            ;

            int visited[ 10000 ];

            char ne[ 5 ] , ps[ 5 ];

            int getdigit(char str[ ])
            {
                
            return (str[ 0 ] - '0'* 1000 + (str[ 1 ] - '0'* 100 + (str[ 2 ] - '0'* 10 + (str[ 3 ] - '0');
            }


            void bfs()
            {
                
            int i , k;
                
                
            char change[ 5 ] , temp;
                
                queue
            <root> Q;
                
                root p , q;
                
                strcpy(p.data , ne);
                
                p.step 
            = 0;
                
                Q.push(p);
                
                
            while (!Q.empty())
                
            {
                    q 
            = Q.front();
                    
                    Q.pop();
                    
                    
            if(strcmp(q.data , ps) == 0)
                    
            {
                        cout 
            << q.step << endl;
                        
                        
            break;
                    }

                    
                    
            for (i = 0 ; i < 4 ; ++ i)
                    
            {
                        
            if (i < 3)
                        
            {
                            strcpy(change , q.data);
                            
                            temp 
            = change[ i ];
                            
                            change[ i ] 
            = change[i + 1];
                            
                            change[i 
            + 1= temp;
                            
                            k 
            = getdigit(change);
                            
                            
            if (visited[ k ] == 0)
                            
            {
                                visited[ k ] 
            = 1;
                                
                                strcpy(p.data , change);
                                
                                p.step 
            = q.step + 1;
                                
                                Q.push(p);
                            }

                            
                            
                        }

                        
                        
                        
            if (q.data[ i ] == '1')
                        
            {
                            strcpy(change , q.data);
                            
                            change[ i ] 
            = '9';
                            
                            k 
            = getdigit(change);
                            
                            
            if (visited[ k ] == 0)
                            
            {
                                visited[ k ] 
            = 1;
                                
                                strcpy(p.data , change);
                                
                                p.step 
            = q.step + 1;
                                
                                Q.push(p);
                            }

                            strcpy(change , q.data); 
                            
                            change[ i ] 
            = '2';
                            
                            k 
            = getdigit(change);
                            
                            
            if (visited[ k ] == 0)
                            
            {
                                visited[ k ] 
            = 1;
                                
                                strcpy(p.data , change);
                                
                                p.step 
            = q.step + 1;
                                
                                Q.push(p);
                            }

                            
                        }

                        
                        
            else
                            
            if( q.data[ i ]  == '9')
                            
            {
                                
                                strcpy(change , q.data); 
                                
                                change[ i ] 
            = '8';
                                
                                k 
            = getdigit(change);
                                
                                
            if (visited[ k ] == 0)
                                
            {
                                    visited[ k ] 
            = 1;
                                    
                                    strcpy(p.data , change);
                                    
                                    p.step 
            = q.step + 1;
                                    
                                    Q.push(p);
                                }

                                
                                strcpy(change , q.data); 
                                
                                change[ i ] 
            = '1';
                                
                                k 
            = getdigit(change);
                                
                                
            if (visited[ k ] == 0)
                                
            {
                                    visited[ k ] 
            = 1;
                                    
                                    strcpy(p.data , change);
                                    
                                    p.step 
            = q.step + 1;
                                    
                                    Q.push(p);
                                }

                                
                            }

                            
                            
            else
                            
            {
                                strcpy(change , q.data); 
                                
                                change[ i ] 
            = change[ i ] - 1;
                                
                                k 
            = getdigit(change);
                                
                                
            if (visited[ k ] == 0)
                                
            {
                                    visited[ k ] 
            = 1;
                                    
                                    strcpy(p.data , change);
                                    
                                    p.step 
            = q.step + 1;
                                    
                                    Q.push(p);
                                }

                                
                                strcpy(change , q.data); 
                                
                                change[ i ] 
            = change[ i ] + 1;
                                
                                k 
            = getdigit(change);
                                
                                
            if (visited[ k ] == 0)
                                
            {
                                    visited[ k ] 
            = 1;
                                    
                                    strcpy(p.data , change);
                                    
                                    p.step 
            = q.step + 1;
                                    
                                    Q.push(p);
                                }

                                
                            }
            //else
                            
                    }
            //for()
                    
                }
            //while()
                
            }



            int main()
            {
                
            int t;
                
                cin 
            >> t;
                
                
            while (t --)
                
            {
                    scanf (
            "%s %s" , ne , ps);
                    
                    memset (visited , 
            0 , sizeof (visited));
                    
                    bfs();
                }

                
                
            return 23;
            }

            posted on 2009-04-19 10:42 此最相思 閱讀(373) 評論(0)  編輯 收藏 引用 所屬分類: bfs

            一本色道久久综合亚洲精品| 久久丫忘忧草产品| 97久久久久人妻精品专区| 日本欧美久久久久免费播放网 | 久久九九久精品国产免费直播| 国产精品99久久久久久www| 一本久久免费视频| 久久久久久久97| 久久精品中文字幕一区| 亚洲精品无码久久久久sm| 色综合久久综精品| 亚洲人成网亚洲欧洲无码久久| 久久99精品国产一区二区三区| 久久久久九国产精品| 久久久噜噜噜久久中文福利| 国产ww久久久久久久久久| 国产精品一区二区久久精品涩爱| 国产一区二区三区久久精品| 久久精品卫校国产小美女| 久久这里只精品国产99热| 精品国产99久久久久久麻豆| 精品久久久久香蕉网| 97精品伊人久久久大香线蕉| 亚洲va久久久久| 麻豆久久| 久久久久亚洲精品天堂| 亚洲AV无码久久精品色欲| 久久国产成人午夜AV影院| 国产L精品国产亚洲区久久| 久久久久亚洲精品天堂| 久久亚洲欧美国产精品 | 国产免费久久精品99re丫y| 久久99精品久久久久久秒播 | 国产精品成人久久久| 久久精品国产一区二区三区| 久久91亚洲人成电影网站| 亚洲国产精品嫩草影院久久 | 久久综合国产乱子伦精品免费| 久久无码AV中文出轨人妻| 久久久久青草线蕉综合超碰| 久久毛片一区二区|