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

            常用鏈接

            統(tǒng)計(jì)

            積分與排名

            百事通

            最新評(píng)論

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


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


            久久伊人精品青青草原高清| 久久综合伊人77777| 亚洲日本va中文字幕久久| 精品久久亚洲中文无码| 蜜臀av性久久久久蜜臀aⅴ| 国产精品一久久香蕉国产线看| 久久亚洲美女精品国产精品| 久久精品视频网| 久久久高清免费视频| 国产精品久久久久…| 美女久久久久久| 日本一区精品久久久久影院| 欧美激情精品久久久久久久| 国产午夜精品理论片久久影视| 国内高清久久久久久| 久久久综合香蕉尹人综合网| 久久久久久国产精品免费无码| 国内精品久久久久久久亚洲| 久久精品人人槡人妻人人玩AV | 久久99精品久久久久久动态图| 99国内精品久久久久久久 | 久久亚洲私人国产精品vA| 性做久久久久久免费观看| 久久青草国产精品一区| 久久人人爽人人爽人人AV东京热| 无码人妻少妇久久中文字幕| 亚洲国产精品久久久久网站| 久久精品亚洲精品国产色婷| 伊人久久综合无码成人网 | 国产精品久久国产精麻豆99网站| 久久精品国产99久久久香蕉| 亚洲国产精品久久久久| 青青热久久综合网伊人| 2021久久精品国产99国产精品| 久久综合香蕉国产蜜臀AV| 国产成人久久精品一区二区三区| 欧美粉嫩小泬久久久久久久| 久久精品国产一区二区电影| 久久人人爽人人爽人人片AV东京热 | 国产精品久久网| 久久国产视屏|