• <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 此最相思 閱讀(360) 評論(0)  編輯 收藏 引用 所屬分類: bfs

            国产免费久久精品丫丫| 国产免费久久久久久无码| 久久青青草原综合伊人| 久久青青草原国产精品免费| 欧洲性大片xxxxx久久久| 久久久久久精品无码人妻| 久久综合亚洲欧美成人| 91精品国产色综久久| 一日本道伊人久久综合影| 久久精品毛片免费观看| 精品久久久久久国产三级 | 综合久久一区二区三区| 日韩人妻无码精品久久免费一| 99久久国产免费福利| 久久久久久久97| 久久久免费观成人影院| 久久人人爽人人爽人人AV东京热 | 久久久久久久人妻无码中文字幕爆| 青青草国产精品久久| 99久久香蕉国产线看观香| 色偷偷偷久久伊人大杳蕉| 久久精品国产99久久久香蕉| 亚洲人成精品久久久久| 久久精品国产亚洲精品| 麻豆成人久久精品二区三区免费| 久久精品无码专区免费| 久久精品国产亚洲AV高清热| 日韩久久无码免费毛片软件| 国产精品久久久久久福利漫画 | 久久精品无码午夜福利理论片 | 伊人久久大香线蕉精品不卡| 久久久久综合网久久| 2021国产精品午夜久久| 国产精品免费久久久久电影网| 色婷婷综合久久久中文字幕| 色偷偷91久久综合噜噜噜噜| 久久精品国产只有精品2020| 伊人久久大香线蕉av一区| 久久久精品视频免费观看| 99精品久久精品一区二区| 精产国品久久一二三产区区别|