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

voip
風的方向
厚德致遠,博學敦行!
posts - 52,comments - 21,trackbacks - 0
               在別人眼里輕而易舉的的事情落在自己身上可能比登天還要難!!
                0-1背包問題:給定n中物品和一個背包。物品i的重量是wi,價值為vi,背包的容量為c。問如何選擇裝入背包中的武平,使得裝入背包中的物品價值最大?
               書上有一行行的算式,證明最優子結構性質和構造遞歸關系。我沒怎么看明白最優子結構,但是我能看懂遞歸關系式!!我記得當時老師叫我們的時候我自己想了好幾天才想明白這個遞歸式,但是始終覺得有點虛,借此我再寫一下!
               設數組m(i,j)代表背包容量為j,可選物品為i,i+1,..n時的最優解(這里的最優解指的是選擇方案,并非正真的最優值),顯然m(1,c)是0-1背包問題的解(這里是書上的錯誤,應該是m[1]中的最大值!!我后來才發現的。。)。這種定義雖然比較拗口,但是還是可以接受的,其實我們也可以這么定義m[i][j],代表背包容量為j,當前選擇物品為a[i]時的最優解,顯然m數組中第n行的最大值是0-1背包問題的解!!

第一種定義的遞歸式如下:
                                               1
   m[i][j]=max{m[i+1][j],m[i+1][j-wi]+vi}  j>=wi;    m[i][j]=m(i+1,j)   0<=j<wi

第二種定義的遞歸式如下:
                              0                  1
   m[i][j]=max{m[i-1][j],m[i-1][j-wi]+vi}    j>=wi;    m[i][j]=m(i-1,j)   0<=j<wi

代碼如下:
#include<stdio.h>
#include
<iostream>
#include
<string.h>
using namespace std;

int max(int x,int y)
{
    
if(x>y)
        
return x;
    
return y;
}


int min(int x,int y)
{
    
if(x>y)
        
return y;
    
return x;
}


template 
<class Type>     
void Knapsack(Type *v,int *w,int c,int n,Type m[][20])//構造m,最優取舍方案函數!!
{
    
int i,j;
    
int jMax=min(w[n]-1,c);

    
for(j=0;j<=jMax;j++)
        m[n][j]
=0;

    
for(j=w[n];j<=c;j++)
        m[n][j]
=v[n];

    
for(i=n-1;i>=1;i--)
    
{
        jMax
=min(w[i]-1,c);

        
for(j=0;j<jMax;j++)
            m[i][j]
=m[i+1][j];

        
for(j=w[i];j<=c;j++)
            m[i][j]
=max(m[i+1][j],m[i+1][j-w[i]]+v[i]);
    }


/*    m[1][c]=m[2][c];
    if(c>=w[1])
        m[1][c]=max(m[1][c],m[2][c-w[1]]+v[1]);
*/
//這里是書上的一個錯誤,并不是m[1][c]就是0-1背包問題的解,事實上m[1]上的所有解都有可能!!
    
//所以還是應該把m[1]上的所有最優構造都算出來,然后去最大值
}


template 
<class Type>                            //構造x數組函數
void Traceback(Type m[][20],int *w,int c,int n,int x[])
{
    
int i;
    
for(i=1;i<n;i++)
    
{
        
if(m[i][c]==m[i+1][c])
            x[i]
=0;
        
else
        
{
            x[i]
=1;
            c
-=w[i];
        }

    }


    x[n]
=(m[n][c])?1:0;
}

int main()
{
    
int w[10],v[10],x[10],m[20][20],c,n,max,c0;
    
int i,j;

    
while(scanf("%d",&n)!=EOF)
    
{
        max
=0;
        memset(m,
0,sizeof(m));
        
for(i=1;i<=n;i++)
        
{
            scanf(
"%d %d",&w[i],&v[i]);
        }

        scanf(
"%d",&c);

        Knapsack(v,w,c,n,m);    
//構造最優取舍方案
        
        
for(i=1;i<=c;i++)
        
{
            
if(m[1][i]>max)
            
{
                max
=m[1][i];
                c0
=i;
            }

        }

        Traceback(m,w,c0,n,x);        
//構造x數組
        
        printf(
"最優矩陣如下:\n");
        
for(i=1;i<=n;i++)
        
{
            
for(j=0;j<=c;j++)
                printf(
"%d ",m[i][j]);
            printf(
"\n");
        }

        
        printf(
"方案如下:\n");
        
for(i=1;i<=n;i++)
            printf(
"%d ",x[i]);
        printf(
"\n");
    }

    
return 0;
}

運行結果如下:

    
               第二種遞歸思路下的代碼和運行過程我就不寫,就初始化和遞歸次序不同!!
               我一個同學經常跟我說,以后自己有孩子,一個賺了1000給我花100,一個賺了10000給我花200,我還是跟著賺1000的吧!!其實問題不在別人,而在自己,努力就成!!!我受益匪淺。。。
posted on 2010-09-11 16:32 jince 閱讀(1863) 評論(0)  編輯 收藏 引用 所屬分類: 算法設計與分析
哈哈哈哈哈哈
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 亚洲永久免费av| 欧美在线观看一二区| 亚洲激情另类| 韩国av一区二区三区四区| 欧美日韩国产综合视频在线观看中文 | 国产免费亚洲高清| 久久久久这里只有精品| 亚洲精品日韩精品| 免费日韩精品中文字幕视频在线| 亚洲人成7777| 尤物yw午夜国产精品视频明星| 国产精品电影网站| 欧美久久综合| 欧美国产先锋| 美女精品视频一区| 久久综合色婷婷| 久久国产精品99国产| 欧美性大战久久久久| 午夜亚洲伦理| 亚洲一区制服诱惑| 国产三区精品| 欧美日韩精品在线播放| 久久精品一区四区| 亚洲在线播放| 99re热这里只有精品免费视频| 欧美系列精品| 久久婷婷久久| 免费观看在线综合色| 欧美一区二区三区婷婷月色 | 欧美国产精品va在线观看| 国产视频在线观看一区二区三区| 欧美日韩一区在线观看| 麻豆精品91| 亚洲精品乱码| 狠狠色伊人亚洲综合成人| 欧美在线91| 欧美一区观看| 香蕉国产精品偷在线观看不卡 | 欧美日韩免费观看中文| 亚洲人成人99网站| 亚洲伊人第一页| 亚洲手机成人高清视频| 亚洲一区www| 久久久精品国产免大香伊| 久久一区二区三区四区| 欧美.www| 99综合视频| 欧美影院精品一区| 久久综合狠狠综合久久激情| 久久久久高清| 欧美日韩精品伦理作品在线免费观看 | 久久精品一区四区| 久久综合影音| 欧美激情自拍| 亚洲免费在线精品一区| 欧美一区二区三区婷婷月色 | 亚洲裸体视频| 亚洲一区精品视频| 好看不卡的中文字幕| 欧美天堂亚洲电影院在线播放 | 国产精品豆花视频| 国产自产2019最新不卡| 亚洲黑丝一区二区| 亚洲欧美日韩精品在线| 免费亚洲网站| 欧美激情精品久久久久久| 亚洲欧美在线播放| 亚洲成人在线视频网站| 一区二区三区日韩欧美精品| 久久精品女人的天堂av| 亚洲国产高清一区| 午夜精品一区二区三区在线播放| 你懂的亚洲视频| 国产麻豆日韩| 亚洲图片在区色| 亚洲国产专区| 久久久久久久综合日本| 亚洲国产精品激情在线观看| 亚洲欧美日韩在线| 欧美日韩18| 在线播放中文一区| 性欧美大战久久久久久久免费观看| 欧美风情在线观看| 国产伦精品一区二区三区免费| 极品少妇一区二区| 欧美日韩国产页| 亚洲第一在线综合网站| 欧美一区二区三区在线视频 | 99视频一区| 玖玖视频精品| 在线精品一区| 狠狠久久婷婷| 伊人蜜桃色噜噜激情综合| 亚洲私人影院| 日韩一级不卡| 欧美日韩一区二区在线视频| 影音先锋一区| 欧美激情a∨在线视频播放| 久久国产精品久久久久久久久久| 国产精品嫩草影院一区二区| 欧美性猛交视频| 国产精品丝袜91| 香蕉久久国产| 午夜精品美女久久久久av福利| 国产精品www网站| 亚洲午夜未删减在线观看| 亚洲精品美女免费| 欧美日韩视频在线| 亚洲欧美日韩在线一区| 久久高清免费观看| 激情久久久久久久久久久久久久久久| 久久精品99无色码中文字幕| 午夜久久tv| 国产一区视频在线观看免费| 久久男女视频| 乱码第一页成人| 国产精品久久久久久久久果冻传媒| 国产亚洲福利| 久久久久青草大香线综合精品| 欧美一区二区三区视频免费播放 | 欧美不卡在线视频| 欧美3dxxxxhd| 久久国产主播| 久久嫩草精品久久久精品一| 99精品国产在热久久| 久久精品国产一区二区电影 | 欧美天天在线| 欧美一区二区三区在线| 欧美精品成人在线| 美日韩免费视频| 欧美日韩亚洲三区| 91久久亚洲| 黄色在线一区| 欧美日韩福利在线观看| 最近中文字幕日韩精品 | 欧美激情一区二区三区 | 久久精品国产亚洲a| 免费观看国产成人| 久久精品国产一区二区三| 亚洲另类一区二区| 亚洲欧美日韩专区| 美女诱惑一区| 亚洲区免费影片| 999亚洲国产精| 亚洲三级色网| 午夜综合激情| 亚洲精品久久久久久久久久久久久| 日韩系列在线| 久久女同精品一区二区| 欧美三级资源在线| 亚洲国产综合91精品麻豆| 欧美在线免费观看亚洲| 夜色激情一区二区| 亚洲精品三级| 久久精品论坛| 中文亚洲字幕| 国产精品欧美经典| 一区二区三区欧美| 亚洲成人资源| 欧美专区在线观看| 午夜精品成人在线视频| 欧美日韩一区二区在线播放| 亚洲精品资源美女情侣酒店| 欧美激情小视频| 国产日韩综合| 亚洲作爱视频| 亚洲性人人天天夜夜摸| 久久精品欧洲| 欧美在线一区二区| 激情成人综合网| 亚洲黄色三级| 国产精品久久久久久久9999| 亚洲永久免费av| av成人免费在线| 国产精品一二三| 免费亚洲一区二区| 欧美色一级片| 免费欧美高清视频| 欧美日韩精选| 久久综合伊人77777| 欧美视频日韩视频| 久久亚洲美女| 欧美日韩中文字幕精品| 久久久综合网站| 国产精品福利在线观看网址| 狼人天天伊人久久| 国产毛片精品视频| 99热在线精品观看| 99热在这里有精品免费| 美女网站久久| 欧美激情精品久久久久久蜜臀| 国内精品视频在线观看| 亚洲综合成人在线| 久久精品人人做人人综合|