• <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>
            posts - 195,  comments - 30,  trackbacks - 0
            #include<iostream>
            #include
            <queue>
            #include
            <vector>
            #include
            <stack>
            using namespace std;
            char a[15][30];
            bool b[15][30];
            int sx,sy,tx,ty;
            int ix[4]={0,0,1,-1};
            int iy[4]={1,-1,0,0};

             
            struct Node
            {
                
            int x,y;
                
            int days;
            };
            class cmp
            {
                
            public:
                    
            bool operator ()(const Node & a, const Node & b)
                    {
                        
            return a.days>b.days;   //СµÄÏÈpop()³öÀ´£¬Í¬Àí¿ÉÒÔ¶¨ÒåÓÅÏÈ´óµÄ¶ÓÁР
                    }    
            };    

            priority_queue
            <Node,vector<Node>,cmp> qu;  
            int bfs()
            {
                 
            int cx,cy;
                 
            int tex,tey;
                 
            int steps;
                 Node node;
                 node.x
            =sx,node.y=sy,node.days=0;
                 
            while(!qu.empty()) qu.pop();
                 qu.push(node);
                 
            while(!qu.empty())
                 {
                     node
            =qu.top();
                     qu.pop();
                     steps
            =node.days;
                     cx
            =node.x;
                     cy
            =node.y;
                     
            for(int i=0;i<4;i++)
                     {
                         tex
            =cx+ix[i];
                         tey
            =cy+iy[i];
                         
            if(tex>=0 && tex<15 && tey>=0 && tey<30 && b[tex][tey]==false&& a[tex][tey]!='#')
                         {
                             node.x
            =tex;
                             node.y
            =tey;
                             
            if(a[tex][tey]=='.')
                                node.days
            =steps+1;
                             
            else if(a[tex][tey]=='M')
                                node.days
            =steps+2;
                             
            else if(a[tex][tey]='T')
                             
            return  steps+1;
                             b[tex][tey]
            =true;
                             qu.push(node);
                         }                 
                     }    
                 }    
            }   
             
            int main()
            {
               
            // freopen("s.txt","r",stdin);
                
            //freopen("key.txt","w",stdout); 
                int ca,i,j;    
                scanf(
            "%d",&ca);
                getchar();
                
            while(ca--)
                {
                    memset(b,
            0,sizeof(b));
                    
            for(i=0;i<15;i++)
                    {
                        
            for(j=0;j<30;j++)
                        {
                            scanf(
            "%c",&a[i][j]);
                            
            if(a[i][j]=='S')
                               sx
            =i,sy=j;
                            
            else if(a[i][j]=='T')
                               tx
            =i,ty=j;
                        }    
                        getchar();
                    }
                    b[sx][sy]
            =1;
                    printf(
            "%d\n",bfs());
                }    
                
            return 0;
            }
            啟發:定義變量時最好能賦予實際的意義!!
                       好的習慣,若是關鍵字可換為大寫字母變量
                       調試一步一步的!肯定是有問題的一步步來
            posted on 2009-05-14 21:49 luis 閱讀(497) 評論(0)  編輯 收藏 引用 所屬分類: 搜索
            <2009年5月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            友情鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产69精品久久久久9999| 久久精品人妻中文系列| 久久精品国产清高在天天线| 午夜精品久久久久| 亚洲日本va午夜中文字幕久久| 波多野结衣久久一区二区| 亚洲中文久久精品无码| 91精品国产高清91久久久久久| 伊人久久综在合线亚洲2019 | 久久精品国产亚洲AV电影| 777米奇久久最新地址| 国产精品综合久久第一页| 区久久AAA片69亚洲| 国产精品久久久久久福利69堂| 国产伊人久久| 久久久久人妻一区精品性色av| 久久WWW免费人成—看片| 亚洲精品美女久久777777| 久久九九免费高清视频| 久久亚洲AV成人无码国产| 久久久亚洲精品蜜桃臀| 久久综合噜噜激激的五月天| 天堂无码久久综合东京热| 国产精品久久久久久久| 中文无码久久精品| 伊人久久精品影院| 91性高湖久久久久| 狠狠色丁香久久综合婷婷| 久久久久亚洲AV成人网人人网站 | 久久精品国产亚洲av麻豆小说 | 免费一级欧美大片久久网| 日本免费一区二区久久人人澡| 久久亚洲日韩精品一区二区三区| 久久久免费观成人影院| 狠狠精品干练久久久无码中文字幕| 国产一区二区三区久久精品| 久久国产精品成人片免费| 日产精品99久久久久久| 久久中文骚妇内射| 精品久久久久久无码专区不卡| 久久ww精品w免费人成|