• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0

            光光住在農村,離他的家不遠有一口井,傳說是光光的祖先開掘的。雖然光光的村子里通了自來水,但是由于這口井井水質量非常的好,因此光光仍然喝這口井里的水。光光非常喜歡這口井,所以他經常去打水。

            光光的家里有 nn 是偶數且n<=18)只桶,這些桶雖然大小相等,但是由于很多都有些破損,所以認為它們是不同的。光光經常挑一根扁擔(帶兩只空桶,必須是空的,且是2 只)去井邊打水。光光每次去井旁都會把桶中的水裝到極限(假設水量無窮,且光光都能夠擔得動)。設光光挑得是xy 兩只桶,則打水一趟需要走 time[x,y]分鐘。光光想要在最少的時間內用自己的力量把家里所有的空桶裝滿。光光覺得這是個難題,于是來找你幫忙。

             

            這道題并不是一道難題,只不過要注意搜索的對象。一開始的時候,我的做法是依次枚舉第12、……、n/2次選取的情況,這樣做的結果是只能通過4組數據。后來改變了搜索對象,依次枚舉第12、……、n個水桶和哪個水桶相匹配。這樣的話全部數據加在一起用時不到0.2s(請自行思考為什么這么做可行)。

            以下是我的代碼:

            #include<stdio.h>
            #define MAXINT 200000000
            long n,ans=MAXINT,a[20][20]={0},used[20]={0};
            void dfs(long dep,long now)
            {
                
            long i,j;
                
            if(dep>n)
                
            {
                   
            if(now<ans) ans=now;
                   
            return;
                }

                
            if(used[dep])
                
            {
                   dfs(dep
            +1,now);
                   
            return;
                }

                used[dep]
            =1;
                
            for(i=dep+1;i<=n;i++)
                  
            if(!used[i]&&a[dep][i]!=0&&now+a[dep][i]<ans)
                  
            {
                     used[i]
            =1;
                     dfs(dep
            +1,now+a[dep][i]);
                     used[i]
            =0;
                  }

                used[dep]
            =0;
            }

            int main()
            {
                FILE 
            *fin,*fout;
                
            long i,j,k,min,t1,t2;
                fin
            =fopen("spring.in","r");
                fscanf(fin,
            "%ld",&n);
                
            for(i=1;i<=n;i++)
                  
            for(j=1;j<=n;j++)
                    fscanf(fin,
            "%ld",&a[i][j]);
                fclose(fin);
            // Read In
                dfs(1,0);
                fout
            =fopen("spring.out","w");
                fprintf(fout,
            "%ld\n",ans);
                fclose(fout);
            return 0;
            }

            posted on 2010-01-06 20:27 lee1r 閱讀(616) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:搜索
            亚洲国产精品久久久久久| 青青草原综合久久大伊人| 久久精品国产福利国产秒| 久久99国产精品一区二区| 94久久国产乱子伦精品免费| 久久一区二区免费播放| 久久精品国产免费观看| 色成年激情久久综合| 久久久久亚洲AV成人网人人网站 | 久久A级毛片免费观看| 精品国产一区二区三区久久久狼| 国产一区二区三区久久| 一本大道久久香蕉成人网 | 久久久久国产成人精品亚洲午夜| 国产成人精品三上悠亚久久| 国产成人精品久久亚洲高清不卡 | 久久久精品国产| 久久激情亚洲精品无码?V| 99re久久精品国产首页2020| 亚洲精品国精品久久99热| 99精品伊人久久久大香线蕉 | 亚洲人成网亚洲欧洲无码久久| 99re久久精品国产首页2020| 久久99热这里只有精品国产| 久久伊人中文无码| 精品久久久久久国产牛牛app | 久久久亚洲裙底偷窥综合| 国产精品VIDEOSSEX久久发布| 久久AV高清无码| 久久精品www人人爽人人| 亚洲AV无码1区2区久久| 国内精品久久久久影院老司| 精品无码久久久久久久动漫| 久久久久久a亚洲欧洲aⅴ | 俺来也俺去啦久久综合网| 久久精品国产亚洲精品2020| 无码久久精品国产亚洲Av影片| 亚洲精品国产美女久久久| 亚洲精品乱码久久久久久中文字幕| 久久久久99这里有精品10| 久久综合久久美利坚合众国|