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

The Fourth Dimension Space

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

POJ 1276-Cash Machine 特殊情況下的背包問題+強剪枝

今天又做了一個背包的題目,有點郁悶~如果單純只考算法的話應該是很容易的,可是由于數據范圍太大,一直都過不了。。。汗~
TLE了2個小時,自己嘗試了N種剪枝方法但還是過不去。最后無奈只好到網絡上搜索了一下,借用了網上大牛代碼中的一個剪枝方法,才過掉這道題的。。。
剛開始的時候我是這么寫的,沒有任何剪枝,結果當然是TLE啦:

#include <iostream>
#include
<cstdio>
#include
<cmath>
#include
<algorithm>
using namespace std;
struct node
{
    
int num;
    
int value;

}
a[15];


int dp[100001];
int n,m;
int cash,N;


int main ()
{
    
int i,j,k;
    
while(scanf("%d%d",&cash,&N)!=EOF)
    
{

        memset(dp,
0,sizeof(dp));
        
for(i=1;i<=N;i++)
            scanf(
"%d%d",&a[i].num,&a[i].value);
        
for(i=1;i<=N;i++)
        
{

            
for(j=1;j<=a[i].num;j++)
            
{

                
for(k=0;k<=cash;k++)
                    
if(k+a[i].value<=cash&&dp[a[i].value+k]<a[i].value+dp[k])
                    
{
                        dp[a[i].value
+k]=a[i].value+dp[k];
                    }


            }

        }

        
int max=0;
        
for(i=0;i<=cash;i++)
            
if(dp[cash]>max)
                max
=dp[cash];
        printf(
"%d\n",max);

    }

}





后來思考了一下,把能想到的剪枝方法都用上了,不過還是。。。
雖然這個方法TLE了,不過還是值得說一下,里面
        if (cash==0||N==0)
        
{
            printf(
"0\n");
            
continue;
        }
必須放在輸入之后,因為cash為0的時候N不一定為0;這時后面應該有讀入的操作,如果不加處理會造成程序異常;
另外此處還添加了排序,貌似可以提高一點速度;

#include <iostream>
#include
<cstdio>
#include
<cmath>
#include
<algorithm>
using namespace std;
struct node
{

    
int num;
    
int value;

}
a[15];

int compare(const void* e1,const void* e2)
{
    node
* a = (node*)e1;
    node
* b = (node*)e2;
    
return b->value - a->value;
}



int dp[100001];
int n,m;
int cash,N;


int main ()
{
    
int i,j,k;
    
while(scanf("%d%d",&cash,&N)!=EOF)
    
{
    

        memset(dp,
0,sizeof(dp));
        
for(i=1;i<=N;i++)
            scanf(
"%d%d",&a[i].num,&a[i].value);
        
if (cash==0||N==0)
        
{
            printf(
"0\n");
            
continue;
        }

        qsort(a
+1,N,sizeof(a[1]),compare);
        
for(i=1;i<=N;i++)
        
{

            
for(j=1;j<=a[i].num;j++)
            
{

                
for(k=cash;k>=a[i].value;k--)
                
{
                    
if(dp[k]<dp[k-a[i].value]+a[i].value)
                        dp[k]
=dp[k-a[i].value]+a[i].value;



                }


            }

        }

        
int maxnum=0;
        
for(i=0;i<=cash;i++)
            
if(dp[i]>maxnum)
                maxnum
=dp[i];
        printf(
"%d\n",maxnum);

            

    }

    



}


最后才是AC的代碼:
這個代碼的優點在于含有狀態轉移方程的部分,它用max變量框定搜索的區間范圍(初始值為0),對可以達到的cash值用ture標定后,再取最大的那個數更新max,這樣最大限制的減少變量搜索的范圍,節約了很多時間,強~

#include <iostream>
#include
<cstdio>
#include
<cmath>
#include
<algorithm>
using namespace std;


struct node
{

    
int num;
    
int value;

}
a[15];




bool dp[100001];
int cash,N;


int main ()
{
    
int i,j,k;
    
while(scanf("%d%d",&cash,&N)!=EOF)
    
{


        memset(dp,
0,sizeof(dp));
        
for(i=1;i<=N;i++)
            scanf(
"%d%d",&a[i].num,&a[i].value);
        
if (cash==0||N==0)
        
{
            printf(
"0\n");
            
continue;
        }


        
int max=0;
        dp[
0]=true;
        
for(i=1;i<=N;i++)
        
{
            
if(a[i].value>cash)
                
continue;
            
for(j=max;j>=0;j--)
            
{
                
if(dp[j]==true)
                
for(k=1;k<=a[i].num;k++)
                
{
                

                    
{
                        
int temp=j+k*a[i].value;
                        
if(temp>cash)
                            
break;
                        
if(temp>max)
                        
{
                            max
=temp;
                            
                        }

                        dp[temp]
=true;
                    }

                }

            }

        }

        printf(
"%d\n",max);

    }

    
return 0;
}





 

posted on 2009-02-20 17:46 abilitytao 閱讀(2570) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            欧美高清视频一区| 亚洲欧美久久| 在线成人性视频| 国产一区二区精品在线观看| 欧美精品国产精品| 欧美日韩大陆在线| 国产精品国产一区二区| 国产精品一区在线观看你懂的| 国产欧美日韩一区| 最新日韩av| 欧美亚洲一区| 欧美国产成人在线| 亚洲无线一线二线三线区别av| 午夜精品久久久久久久99黑人| 久久国产精品高清| 欧美精品一区二区三区四区| 国产精品久久久久久久久久直播 | 欧美日韩视频| 国产精品主播| 亚洲欧洲在线一区| 香蕉久久夜色精品国产使用方法 | 亚洲图片在线| 久久久人成影片一区二区三区| 欧美日本韩国一区| 精品成人国产| 午夜精品在线| 亚洲黄色天堂| 欧美亚洲综合另类| 欧美日韩国产高清视频| 极品日韩久久| 午夜免费日韩视频| 亚洲人永久免费| 久久婷婷激情| 国产自产女人91一区在线观看| 亚洲视频一二区| 亚洲欧洲精品天堂一级| 久久久精品性| 国产三级欧美三级| 亚洲一区免费网站| 亚洲欧洲一区二区三区在线观看 | 亚洲精品一区二区三区在线观看 | 一区二区三区免费网站| 久久午夜视频| 午夜精品视频一区| 国产精品一区二区女厕厕| 亚洲视频大全| 亚洲伦理网站| 欧美日本在线播放| 亚洲国产高清在线观看视频| 久久久亚洲精品一区二区三区 | 久久久人成影片一区二区三区| 国产欧美一区二区三区久久人妖 | 亚洲女人av| 亚洲人成77777在线观看网| 久久久久9999亚洲精品| 国产欧美日韩精品丝袜高跟鞋| 国产精品99久久久久久久女警| 亚洲国产小视频在线观看| 香蕉av777xxx色综合一区| 一区二区日本视频| 国产精品久久久久永久免费观看| 亚洲女女女同性video| 亚洲女人天堂av| 国产亚洲精品久久久久婷婷瑜伽| 欧美在线不卡| 久久亚洲国产成人| 亚洲老板91色精品久久| 亚洲精品在线视频| 国产精品www网站| 欧美日韩精品中文字幕| 中文精品视频| 香蕉久久夜色精品国产| 亚洲第一视频网站| 亚洲国产日韩欧美在线图片| 欧美精品国产精品| 性欧美长视频| 蜜臀久久99精品久久久画质超高清| 亚洲日本在线观看| 亚洲少妇中出一区| 一区二区三区在线观看欧美 | 欧美一区二区在线免费播放| 在线观看国产精品淫| 亚洲黄色在线观看| 国产精品色一区二区三区| 久久天堂av综合合色| 免费在线欧美黄色| 性色av一区二区三区| 老司机免费视频一区二区| 亚洲一区二区三区午夜| 欧美综合国产精品久久丁香| 亚洲精品乱码久久久久久黑人| 亚洲综合日本| 亚洲免费黄色| 久久精品在这里| 亚洲永久在线| 久久婷婷久久| 欧美在线免费观看亚洲| 欧美高清视频在线| 久久精品日韩一区二区三区| 欧美日韩成人在线播放| 久久在线免费| 国产精品影院在线观看| 亚洲精品一区二区三区99| 在线欧美视频| 欧美一区二区三区另类 | 欧美一区综合| 欧美乱人伦中文字幕在线| 久久久久久综合网天天| 国产精品高潮呻吟久久av无限| 欧美刺激性大交免费视频| 国产乱码精品| 亚洲私人影院在线观看| 一区二区三区免费在线观看| 久久尤物电影视频在线观看| 欧美一区二区三区婷婷月色 | 亚洲人成在线影院| 久久久久久久久久久成人| 欧美亚洲一级| 国产精品久久久久77777| 亚洲精品乱码| 亚洲麻豆av| 欧美福利一区| 欧美国产日韩a欧美在线观看| 好吊日精品视频| 亚洲欧美制服另类日韩| 欧美一区二区三区视频| 国产精品久久久久9999| 一区二区三区产品免费精品久久75 | 国产亚洲美州欧州综合国| 亚洲一级黄色| 亚洲欧美日韩中文在线制服| 国产精品成人播放| 制服丝袜亚洲播放| 一区二区高清视频| 欧美伦理影院| 亚洲免费观看高清完整版在线观看熊 | 亚洲精品美女在线观看播放| 在线观看中文字幕不卡| 久久久久免费| 欧美高清hd18日本| 亚洲精品日韩欧美| 欧美三级在线播放| 国产精品99久久久久久久久久久久 | 亚洲视频 欧洲视频| 欧美日韩免费在线视频| 99ri日韩精品视频| 亚洲欧美日韩综合国产aⅴ| 国产精品视频第一区| 欧美在线免费观看| 欧美a级片一区| 亚洲人成网站在线观看播放| 欧美理论片在线观看| 一区二区三区欧美激情| 欧美亚洲一级片| 亚洲激情在线激情| 欧美日韩一区二区三区视频| 国产精品99久久久久久久久| 久久国产精品99精品国产| 韩国av一区二区三区四区| 久久视频免费观看| 亚洲国产另类久久精品| 午夜精品一区二区三区在线播放| 国内精品久久久久影院 日本资源| 久久精品国产96久久久香蕉| 亚洲国产合集| 欧美亚洲一区二区在线| 亚洲欧洲日韩在线| 国产精品国产三级国产专播精品人| 先锋a资源在线看亚洲| 亚洲国产精品久久久久秋霞影院 | 欧美激情第六页| 亚洲视频免费看| 在线电影国产精品| 国产精品久久久久av免费| 久久人人爽爽爽人久久久| 99精品视频一区二区三区| 欧美有码视频| 99精品国产高清一区二区| 国产午夜精品福利| 欧美日韩国产专区| 久久久久久自在自线| 亚洲香蕉在线观看| 亚洲国产另类久久久精品极度| 欧美在线日韩在线| 中国成人亚色综合网站| 在线日韩中文| 国产精品自在欧美一区| 欧美精品v日韩精品v国产精品| 欧美一区二区三区在线看| 夜夜嗨av一区二区三区免费区| 免播放器亚洲一区| 久久久99精品免费观看不卡| 亚洲图片在线| 一本大道久久a久久综合婷婷| 一区二区三区中文在线观看| 国产乱理伦片在线观看夜一区| 欧美日韩美女在线| 欧美精品日韩三级| 欧美风情在线| 暖暖成人免费视频|