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

Onway

我是一只菜菜菜菜鳥...
posts - 61, comments - 56, trackbacks - 0, articles - 34

pku 1948 0-1背包 加強版

Posted on 2010-08-08 11:08 Onway 閱讀(427) 評論(0)  編輯 收藏 引用 所屬分類: 傷不起的ACM

pku 1948 Triangular Pastures 0-1背包思想

題意:有N個不同長度fence,求用所有fence能組成的最大三角形的面積。

幾天前就看到這個題了,今天才過掉,對這個題感覺非常失敗。

首先第一想法是:將總邊長的三分之一做為背包容量,進行一次0-1背包,然后再用剩下的三分之二邊長的一半做背包容量,再進行一次0-1背包。但問題是進行第一次背包的時候要記錄使用過的邊,以便在第二次背包時不再使用。但由于能力問題,動手寫過兩次都無法解決這個問題。百度一下,發現人家也想到這個思路,但都被否決了,原因是這樣的思路,通過找三邊差值最小,并不能保證面值最大。

然后我就沒想法了。直到今天,看到marvin(網上認識的ACMer)的blog,才知道思路應該是這樣的:枚舉第一條邊和第二條邊的組合,用sgn[j][k]標記第一邊長為j,第二邊長為k。如果能從給出的邊里組成這兩條邊,則進行標記。

看到這個思路后,發現原來就是這么簡單,但怎么自己就沒有想到呢。然后馬上動手就寫,又WA到快吐血。

雖然很快發現問題出在了用背包枚舉兩邊組合的那幾行代碼,但就是改不過來,在那里糾結得跳樓的心都有。做了一個星期的背包,居然連這幾行代碼都寫不出,都羞死了。

寫不出那幾個代碼的原因:1,對用背包枚舉兩邊組合的原理理解不透徹。2,沒有認真分析組合情況。3,做單純的背包題時留下的思維僵硬。4.,將或運算想當然的寫成了并運算。

AC了這個題目后,對背包枚舉兩邊組合部分的三重循環的邊界條件感覺還是很抽象。再深入去想,才逐漸明了。

1,需要枚舉的兩條邊的長度都是不能超過總長的一半的。

2,由于各邊只能使用一次,同0-1背包,循環需要用逆序。

3,對于第條邊,如果已有sgn[j-fence[i]][k]或者sgn[j][k-fence[i]],則必有sgn[j][k]。由于這種組合只需滿足其中一個即可,所以j和k都要枚舉到0并且要保證j>=fence[i]或者k>=fence[i]。

4,優化速度的問題。由于j和k可能會出現長度交換時會進行重復計算,所以在計算的時候可以只取j>=k的情況,但枚舉組合的時候能取j>=k進行枚舉嗎?表面上對j>=k的情況進行過枚舉,似乎就滿足目的了。但實際上,這樣的j>=k的限制導致,能枚舉,但不能有效地標記組合。

設sgn[j0][k0]為確定組合(0<=k0<=j0)  (確定組合即為能夠確定這種組合的存在與否)

若k0+fenc[i]>j0時

fence[i]只能加到第一邊,得到確定組合sgn[j0+fence[i]][k0]

當fence[i+1]+k0>j0+fence[i]時,(顯然,這時fence[i+1]>fence[i])

fence[i+1]又只能加到第一邊。

這樣sgn[j0+fence[i+1]][k0+fence[i]]的組合就只能標記為失敗了。

解決方式是:對于fence[i],只要第一邊不使用這個fence[i]的時候,必須要讓它能夠加到第二邊。這樣去k=j+fence[i]即可。

#include <iostream>
#include 
<math.h>
using namespace std;
const int MAX=800;
bool sgn[MAX+1][MAX+1];
int fence[41];
int main()
{
    
double find(int,int,int);
    
int i,j,k,n,sum=0;
    scanf(
"%d",&n);
    
for(i=1;i<=n;++i)    {scanf("%d",&fence[i]);sum+=fence[i];}

    memset(sgn,
0,sizeof(sgn));
    sgn[
0][0]=1;
    
for(i=1;i<=n;++i)
        
for(j=sum/2;j>=0;--j)
            
for(k=j+fence[i];k>=0;--k)
                
if((j>=fence[i]&&sgn[j-fence[i]][k])||
                    (k
>=fence[i]&&sgn[j][k-fence[i]]))
                    sgn[j][k]
=1;            


    
double ans=-0.01,tmp;
    
for(i=1;i<=sum/2;++i)
        
for(j=1;j<=i;++j)
            
if(sgn[i][j])
            {
                tmp
=find(sum-i-j,i,j);
                
                ans
=ans>tmp?ans:tmp;
            }
    cout
<<int(ans*100)<<endl;
    
return 0;
}
double find(int x,int y,int z)
{
    
if(x+y>z&&x+z>y&&y+z>x)
        
return    sqrt(1.0*(x+y+z)*(x+y-z)*(x+z-y)*(y+z-x))*0.25;
    
else
        
return -0.01;
}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩国产色站一区二区三区| 亚洲欧美乱综合| 欧美激情一二区| 女同一区二区| 欧美精品啪啪| 欧美四级电影网站| 国产精品热久久久久夜色精品三区| 欧美视频在线观看| 国产精品日韩欧美一区二区| 国产乱码精品一区二区三区不卡| 国产欧美精品日韩| 狠狠干狠狠久久| 亚洲黄色天堂| 中日韩美女免费视频网址在线观看 | 午夜免费在线观看精品视频| 亚洲欧美日韩在线综合| 久久狠狠久久综合桃花| 国产精品久久久久久久久久免费| 国产精品国产三级国产aⅴ9色| 国内久久精品| 激情文学一区| 国语自产精品视频在线看8查询8| 国产精品啊啊啊| 欧美国产视频一区二区| 欧美jizz19hd性欧美| 亚洲免费视频一区二区| 亚洲一区影音先锋| 久久久欧美一区二区| 亚洲国产高潮在线观看| 欧美一区1区三区3区公司| 久久久精品2019中文字幕神马| 欧美国产一区二区在线观看| 国产精品户外野外| 亚洲国产导航| 久久成人免费| 亚洲美女在线看| 久久视频免费观看| 国产精品久久97| 在线免费观看欧美| 欧美一区二区三区日韩| 亚洲日韩欧美一区二区在线| 久久福利资源站| 国产精品国产三级国产普通话三级 | 伊人久久亚洲美女图片| 中文在线不卡视频| 欧美成人性生活| 久久精品人人做人人爽电影蜜月| 欧美四级在线观看| 夜色激情一区二区| 欧美成人久久| 久久久久久伊人| 黄色亚洲网站| 久久久爽爽爽美女图片| 亚洲一级片在线看| 欧美日韩亚洲在线| aⅴ色国产欧美| 亚洲国产精品久久| 麻豆91精品| 亚洲国产高清一区| 麻豆九一精品爱看视频在线观看免费| 亚洲午夜久久久久久久久电影院 | 另类av导航| 国内精品久久久| 一区二区三区av| 欧美激情视频一区二区三区不卡| 国产视频一区二区三区在线观看| 亚洲日本视频| 久热精品视频在线观看一区| 99re8这里有精品热视频免费 | 亚洲成色www8888| aaa亚洲精品一二三区| 欧美福利视频在线| 亚洲日本中文字幕| 亚洲大黄网站| 欧美14一18处毛片| 亚洲精品乱码久久久久久按摩观| 欧美大片第1页| 老司机免费视频一区二区| 亚洲丰满少妇videoshd| 亚洲国产99| 欧美破处大片在线视频| 伊人久久大香线蕉综合热线| 美女脱光内衣内裤视频久久网站| 久久久久久91香蕉国产| 亚洲国内欧美| 亚洲免费观看视频| 国产精品永久免费| 蜜桃av一区二区| 欧美精品九九99久久| 欧美一级网站| 美腿丝袜亚洲色图| 亚洲在线1234| 久久精品成人| 99视频有精品| 午夜亚洲福利| 亚洲美女av黄| 亚洲自拍偷拍福利| 狠狠久久婷婷| 亚洲大片一区二区三区| 欧美日韩国产一区二区| 久久久视频精品| 欧美伦理a级免费电影| 久久九九热re6这里有精品| 一本大道久久精品懂色aⅴ| 午夜国产精品影院在线观看| 欧美一级一区| 久久人人97超碰国产公开结果 | 欧美午夜精品理论片a级按摩| 欧美一区二区三区四区夜夜大片 | 亚洲性图久久| 国产精品久久久久免费a∨| 久久成年人视频| 国产欧美日韩三区| 久久国产直播| 欧美成人午夜激情在线| 亚洲欧洲三级电影| 国产精品成人在线| 亚洲欧美久久久| 亚洲网站啪啪| 久久在线免费观看| 亚洲欧美999| 日韩视频精品| 久久久久久亚洲精品杨幂换脸| 亚洲无线观看| 欧美精品午夜| 欧美国产精品专区| 在线成人激情| 久久国产精品99国产| 先锋亚洲精品| 国产精品久久久免费| 亚洲欧洲日夜超级视频| 亚洲福利一区| 久久久久久自在自线| 久久综合亚州| 狠狠操狠狠色综合网| 欧美一区激情| 久久午夜影视| 国内精品伊人久久久久av影院| 午夜精品三级视频福利| 亚洲综合色婷婷| 欧美深夜影院| 99这里只有久久精品视频| 99热这里只有成人精品国产| 欧美激情在线免费观看| 亚洲国产精品久久久久婷婷884 | 国产精品久久激情| 亚洲国产三级在线| 亚洲精品之草原avav久久| 欧美电影免费观看网站| 亚洲国产精品嫩草影院| 日韩午夜三级在线| 欧美日韩成人| 亚洲一级黄色片| 久久久另类综合| 在线免费不卡视频| 欧美日韩视频免费播放| 一本综合久久| 久久久久99| 亚洲欧洲在线观看| 欧美性理论片在线观看片免费| 亚洲线精品一区二区三区八戒| 亚洲一区二区三区成人在线视频精品 | 日韩视频免费大全中文字幕| 欧美丝袜一区二区三区| 亚洲欧美日韩精品久久久| 久久一区中文字幕| 亚洲七七久久综合桃花剧情介绍| 免费永久网站黄欧美| 久久裸体艺术| 老司机午夜精品视频| 国产精品久久久久av| 久久亚洲电影| 国产精品日日摸夜夜摸av| 亚洲福利专区| 久久精品人人做人人综合| 欧美高清在线视频| 亚洲激情欧美| 亚洲欧美美女| 亚洲高清激情| 欧美日韩综合不卡| 欧美伊久线香蕉线新在线| 欧美激情在线免费观看| 亚洲图片欧美一区| 在线免费观看日本欧美| 欧美午夜精品理论片a级大开眼界| 久久精品国产久精国产思思| 亚洲欧洲精品成人久久奇米网 | 国产一区二区中文| 欧美成年人视频网站| 亚洲欧美日韩一区二区三区在线观看 | 国产精品私房写真福利视频| 久久躁狠狠躁夜夜爽| 亚洲午夜羞羞片| 亚洲国产天堂久久综合| 久久久久久黄| 亚洲天堂av高清| 亚洲狼人综合| 影音欧美亚洲| 国产日韩欧美三区| 国产精品久久中文|