青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

The Fourth Dimension Space

枯葉北風寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

POJ 3414-Pots BFS (代碼好長啊 ,建議大家不要看了)

有史以來寫的最爛的一個程序,居然寫到5000B,勉強16MS AC.
題意就是有名的倒水游戲,給你2個一定容量的容器,然后要求你配出一定兩的溶液并輸出每一步的決策;
此題的算法當然是BFS啦,不過貌似有人告訴我說數(shù)論里有更好的方法,我感覺也是這樣,我寫的代碼實在是有點冗長。。。
    algorithm=搜索+回溯。   有這幾個字就足夠了;
值得一提的是,本題中不能將一個結點反復入隊,而避免的方法不是更改flag標志,而是判斷這個結點是否有前件。
我總結下這類題的規(guī)律:
一是BFS代碼一般都很長;
二是要回溯的題目不能讓你個元素二次入隊。因為這樣會修改已經(jīng)設定好的元素的前件,到時候就無法回溯了。
代碼還是貼上來吧,不值得學習,僅供參考;
#include <iostream>
#include
<cmath>
#include
<algorithm>
using namespace std;
struct node2
{
    
int flag;
    
int prex;
    
int prey;

}
;

struct node
{
    
int x;
    
int y;
}
;



node line[
10000000];
node record[
100000];
node2 data[
201][201];



int main ()
{

    
int a,b,c;
    scanf(
"%d%d%d",&a,&b,&c);
    
int front=1;
    
int rear=1;
    line[
1].x=0;
    line[
1].y=0;

    
while(front<=rear)
    
{

        
if(line[front].x==c||line[front].y==c)
            
break;


        
if(data[line[front].x][line[front].y].flag==0)
        
{
            data[line[front].x][line[front].y].flag
=1;
            
if(line[front].x!=a&&data[a][line[front].y].flag==0&&data[a][line[front].y].prex==0&&data[a][line[front].y].prey==0)
            
{

                rear
++;
                line[rear].x
=a;
                line[rear].y
=line[front].y;
                data[line[rear].x][line[rear].y].prex
=line[front].x;
                data[line[rear].x][line[rear].y].prey
=line[front].y;

            }

            
if(line[front].y!=b&&data[line[front].x][b].flag==0&&data[line[front].x][b].prex==0&&data[line[front].x][b].prey==0)
            
{

                rear
++;
                line[rear].x
=line[front].x;
                line[rear].y
=b;
                data[line[rear].x][line[rear].y].prex
=line[front].x;
                data[line[rear].x][line[rear].y].prey
=line[front].y;
            }

            
if(line[front].x!=0&&data[0][line[front].y].flag==0&&data[0][line[front].y].prex==0&&data[0][line[front].y].prey==0)
            
{

                rear
++;
                line[rear].x
=0;
                line[rear].y
=line[front].y;
                data[line[rear].x][line[rear].y].prex
=line[front].x;
                data[line[rear].x][line[rear].y].prey
=line[front].y;

            }

            
if(line[front].y!=0&&data[line[front].x][0].flag==0&&data[line[front].x][0].prex==0&&data[line[front].x][0].prey==0)
            
{

                rear
++;
                line[rear].x
=line[front].x;
                line[rear].y
=0;
                data[line[rear].x][line[rear].y].prex
=line[front].x;
                data[line[rear].x][line[rear].y].prey
=line[front].y;
            }

            
if(line[front].x!=0&&line[front].y!=b)
            
{


                
if(line[front].x+line[front].y>b&&data[line[front].x-b+line[front].y][b].flag==0&&data[line[front].x-b+line[front].y][b].prex==0&&data[line[front].x-b+line[front].y][b].prey==0)
                
{
                    rear
++;
                    
int temp;
                    temp
=b-line[front].y;

                    line[rear].x
=line[front].x-temp;
                    line[rear].y
=b;
                    data[line[rear].x][line[rear].y].prex
=line[front].x;
                    data[line[rear].x][line[rear].y].prey
=line[front].y;

                }

                
else if(data[0][line[front].x+line[front].y].flag==0&&data[0][line[front].x+line[front].y].prex==0&&data[0][line[front].x+line[front].y].prey==0)
                
{
                    rear
++;
                    
int temp;
                    line[rear].x
=0;
                    line[rear].y
=line[front].x+line[front].y;
                    data[line[rear].x][line[rear].y].prex
=line[front].x;
                    data[line[rear].x][line[rear].y].prey
=line[front].y;

                }

            }


                
////////////////////////////////////////////////////////////////////////////
            if(line[front].y!=0&&line[front].x!=a)
            
{
    
                
                
if(line[front].x+line[front].y>a&&data[a][line[front].y-a+line[front].x].flag==0&&data[a][line[front].y-a+line[front].x].prex==0&&data[a][line[front].y-a+line[front].x].prey==0)
                
{
                    
int temp;
                    rear
++;
                    temp
=a-line[front].x;
                    line[rear].y
=line[front].y-temp;
                    line[rear].x
=a;
                    data[line[rear].x][line[rear].y].prex
=line[front].x;
                    data[line[rear].x][line[rear].y].prey
=line[front].y;

                }

                
else if(data[line[front].x+line[front].y][0].flag==0&&data[line[front].x+line[front].y][0].prex==0&&data[line[front].x+line[front].y][0].prey==0)
                
{
                    
int temp;
                    rear
++;
                    line[rear].y
=0;
                    line[rear].x
=line[front].x+line[front].y;
                    data[line[rear].x][line[rear].y].prex
=line[front].x;
                    data[line[rear].x][line[rear].y].prey
=line[front].y;
                }

            }



        }

        front
++;
    }


    
if(front>rear)
    
{
        printf(
"impossible\n");
        
return 0;
    }

    
int pos=1;
    
int markx=line[front].x;
    
int marky=line[front].y;
    
int tempx;
    
int tempy;
    
while(1)
    
{
        
if(markx==0&&marky==0)
        
{
            
break;
        }

        record[pos].x
=markx;
        record[pos].y
=marky;
        
int tempx=markx;
        
int tempy=marky;
        markx
=data[tempx][tempy].prex;
        marky
=data[tempx][tempy].prey;
        pos
++;
    }

    record[pos].x
=0;
    record[pos].y
=0;
    printf(
"%d\n",pos-1);

    
int i;
    
for(i=pos;i>=2;i--)
    
{
        
if(record[i].x==0&&record[i-1].x==a&&record[i].y==record[i-1].y)
            printf(
"FILL(1)\n");
        
else if(record[i].y==0&&record[i-1].y==b&&record[i].x==record[i-1].x)
                printf(
"FILL(2)\n");
        
else if(record[i].x!=0&&record[i-1].x==0&&record[i].y==record[i-1].y)
            printf(
"DROP(1)\n");
        
else if(record[i].y!=0&&record[i-1].y==0&&record[i].x==record[i-1].x)
            printf(
"DROP(2)\n");
        
else if(record[i].x>record[i-1].x)
            printf(
"POUR(1,2)\n");
        
else if(record[i].x<record[i-1].x)
            printf(
"POUR(2,1)\n");
    }

    
return 0;
}

    








posted on 2009-03-01 01:10 abilitytao 閱讀(1052) 評論(0)  編輯 收藏 引用


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


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产三级欧美三级日产三级99| 夜夜嗨av一区二区三区| 你懂的视频一区二区| 91久久在线观看| 欧美激情综合| 欧美成人福利视频| 99re亚洲国产精品| 久久精品理论片| 亚洲高清视频的网址| 亚洲日本电影在线| 美国十次了思思久久精品导航| 国产欧美日韩高清| 久久久久久久久伊人| 久久另类ts人妖一区二区| 亚洲高清三级视频| 国产亚洲一区二区在线观看| 亚洲精品乱码久久久久久黑人| 欧美国产日韩视频| 久久久久国产免费免费| 麻豆精品在线观看| 午夜精品成人在线视频| 日韩一区二区精品视频| 亚洲综合国产精品| 久久综合给合久久狠狠狠97色69| 欧美日韩日韩| 欧美成人免费小视频| 久久色中文字幕| 久久中文字幕一区二区三区| 激情亚洲网站| 欧美日韩国产系列| 国产精品成人观看视频免费| 欧美va天堂va视频va在线| 欧美一区二区三区在| 亚洲在线观看| 欧美韩日视频| 蜜桃精品久久久久久久免费影院| 欧美精品一卡| 日韩视频在线你懂得| 欧美亚洲一区二区在线| 狠狠v欧美v日韩v亚洲ⅴ| 99精品99久久久久久宅男| 在线日韩日本国产亚洲| 久久久久网址| 老司机一区二区三区| 久久精品中文字幕一区| 亚洲国产视频直播| 午夜精品久久久久久久久久久| 欧美日韩免费区域视频在线观看| 亚洲高清精品中出| 久久男女视频| 久久成人精品视频| 欧美大胆a视频| 欧美一区二区三区精品 | 欧美精品一区二区久久婷婷| 国产揄拍国内精品对白| 欧美亚洲视频在线看网址| 亚洲第一搞黄网站| 亚洲二区在线视频| 在线日韩中文字幕| 日韩视频三区| 一本色道**综合亚洲精品蜜桃冫| 国产精品99久久久久久人| av72成人在线| 亚洲欧美视频一区二区三区| 亚洲国产高清高潮精品美女| 欧美 日韩 国产在线| 亚洲第一在线| 91久久在线视频| 亚洲成色999久久网站| 亚洲成人在线视频播放 | 欧美黑人在线播放| 欧美日韩国产免费| 一本色道久久综合狠狠躁篇的优点| 一区二区久久久久| 性色一区二区| 欧美ed2k| 欧美精品一区二区久久婷婷| 国产香蕉久久精品综合网| 亚洲精品在线视频观看| 亚洲视频一二三| 中文网丁香综合网| 国产一区二区三区四区在线观看| 亚洲精品小视频在线观看| 午夜视频一区| 久久国产直播| 国产美女精品人人做人人爽| 久久亚洲精品伦理| 欧美激情成人在线视频| 影院欧美亚洲| 亚洲另类视频| 欧美国产精品人人做人人爱| 在线亚洲电影| 亚洲国产视频直播| 国产精品久久网| 欧美国产激情| 久久综合一区| 亚洲一级黄色片| 久久视频一区二区| 午夜精品久久久久久| 亚洲国产成人久久综合一区| 亚洲欧美日本精品| 欧美国产一区二区在线观看| 亚洲私人影院在线观看| 久久在线免费观看视频| 午夜亚洲福利| 欧美日韩国产首页在线观看| 欧美成人情趣视频| 久久久久亚洲综合| 欧美成人精品在线| 亚洲国产精品久久久久秋霞影院| 久久精品国产99| 亚洲免费视频成人| 国产精品国产亚洲精品看不卡15| 久久亚洲午夜电影| 久久人人97超碰精品888| 99热精品在线观看| 久久欧美肥婆一二区| 在线不卡欧美| 久久精品男女| 国产精品99久久久久久久久| 亚洲人成7777| 美日韩在线观看| 99pao成人国产永久免费视频| 欧美在线三区| 久久久伊人欧美| 国产主播精品在线| 欧美一区二区三区播放老司机| 在线国产日韩| 久久亚洲二区| 美女主播精品视频一二三四| 米奇777超碰欧美日韩亚洲| 免费欧美在线视频| 久久艳片www.17c.com| 欧美国产日韩视频| avtt综合网| 亚洲欧美bt| 午夜视频一区| 国产亚洲综合精品| 欧美激情综合色| 国产精品国产三级国产aⅴ入口| 亚洲国产色一区| 亚洲无吗在线| 久久久久一区二区三区| 久久久久久综合| 在线观看成人网| 裸体素人女欧美日韩| 亚洲欧美日韩天堂一区二区| 一区二区三区你懂的| 国产夜色精品一区二区av| 久热精品视频在线| 麻豆国产va免费精品高清在线| 免费观看一级特黄欧美大片| 欧美午夜在线观看| 一区二区高清视频| 久久久www成人免费精品| 在线精品观看| 国产精品国产三级国产aⅴ浪潮| 午夜精品福利一区二区蜜股av| 久久久久久久高潮| 亚洲麻豆av| 国产精品午夜春色av| 欧美激情第10页| 国产午夜精品全部视频在线播放| 亚洲高清资源综合久久精品| 欧美日韩免费区域视频在线观看| 亚洲国产精品久久久久秋霞不卡| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 欧美va亚洲va香蕉在线| 亚洲二区在线观看| 欧美新色视频| 亚洲国产欧美一区二区三区丁香婷| 久久精品视频99| 欧美二区视频| 亚洲欧美美女| 激情六月综合| 免费亚洲一区二区| 亚洲午夜激情网站| 国产欧美日韩亚洲一区二区三区 | 这里只有精品丝袜| 国产综合网站| 国产精品igao视频网网址不卡日韩| 久久精品国产999大香线蕉| 在线欧美亚洲| 久久亚洲图片| 麻豆精品一区二区综合av| 欧美日韩第一区| 亚洲伦理在线| 国产一区二区在线观看免费播放| 美国十次了思思久久精品导航| 亚洲女性裸体视频| 亚洲视频免费| 在线精品视频一区二区三四| 欧美激情a∨在线视频播放| 香蕉免费一区二区三区在线观看 | 欧美大片免费久久精品三p| 性久久久久久久久久久久| 香蕉久久一区二区不卡无毒影院| 亚洲电影免费观看高清完整版| 国产精品入口| 亚洲一区制服诱惑|