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

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>
            欧美成人tv| 亚洲在线中文字幕| 久久激情中文| 亚洲国产欧美另类丝袜| 欧美在线免费一级片| 欧美视频免费在线观看| 日韩亚洲视频在线| 亚洲国产第一页| 久久人体大胆视频| **网站欧美大片在线观看| 欧美不卡福利| 欧美福利视频网站| 一区二区久久| 亚洲一级高清| 国内精品久久久| 久热国产精品| 美女视频网站黄色亚洲| 亚洲精品女人| 夜夜精品视频| 国外成人网址| 亚洲国产小视频在线观看| 欧美日韩免费观看一区| 亚洲欧美日韩精品久久久久| 亚洲直播在线一区| 一区精品久久| 亚洲乱码精品一二三四区日韩在线| 欧美日韩精品系列| 久久国产精品久久精品国产| 久久久精品2019中文字幕神马| 最近中文字幕日韩精品| 亚洲精品一区在线观看香蕉| 国产伦精品一区二区三区视频孕妇| 久久久久久久尹人综合网亚洲| 久久香蕉国产线看观看网| 亚洲乱码久久| 午夜视频一区在线观看| 亚洲欧洲精品天堂一级| 一区二区三区欧美日韩| 在线国产日韩| 亚洲最新色图| 国产字幕视频一区二区| 亚洲精品黄色| 一区视频在线| 在线一区视频| 亚洲欧洲日产国产综合网| 亚洲一区二区毛片| 亚洲片在线资源| 亚洲欧美在线免费观看| 亚洲日本中文| 久久九九热免费视频| 亚洲视频大全| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲女人小视频在线观看| 免费成人你懂的| 久久久久久电影| 欧美性天天影院| 亚洲国产精品一区| 亚洲成人资源| 欧美一区二区三区免费在线看| 日韩一级精品视频在线观看| 老鸭窝亚洲一区二区三区| 在线精品国精品国产尤物884a| 狂野欧美激情性xxxx| 欧美日韩情趣电影| 欧美成年人网站| 国产亚洲欧美日韩精品| 亚洲午夜伦理| 亚洲欧美制服中文字幕| 欧美色网一区二区| 亚洲精品在线观看视频| 亚洲国产精品精华液2区45| 久久激情视频久久| 久久久久久久999| 国产婷婷成人久久av免费高清| 国产精品99久久不卡二区 | 亚洲欧美久久久| 亚洲一区二区三区四区五区午夜 | 久久午夜精品| 玖玖玖国产精品| 激情一区二区三区| 久久成人精品视频| 久久一区激情| 曰本成人黄色| 老鸭窝亚洲一区二区三区| 亚洲福利视频三区| 99re成人精品视频| 欧美日韩一区二区在线观看视频| 亚洲美女视频在线观看| 一区二区三区欧美日韩| 久久亚洲影音av资源网| 欧美黑人多人双交| 妖精成人www高清在线观看| 欧美日韩国产成人精品| 一区二区三区欧美在线| 亚洲尤物在线| 国产一区免费视频| 久久免费黄色| 日韩午夜电影av| 午夜在线一区| 在线日韩av片| 欧美日韩国产在线播放网站| 亚洲午夜精品17c| 久久久久久综合网天天| 日韩视频不卡| 国产欧美精品日韩区二区麻豆天美| 日韩亚洲不卡在线| 欧美诱惑福利视频| 亚洲大片在线观看| 欧美日韩国产精品| 久久亚洲综合网| 亚洲理论在线| 久久久久一区二区| 一本色道久久综合亚洲二区三区| 国产欧美日本一区二区三区| 欧美一区二区三区免费大片| 亚洲日韩欧美视频一区| 久久爱另类一区二区小说| 亚洲日本aⅴ片在线观看香蕉| 欧美三级免费| 老色批av在线精品| 亚洲少妇在线| 亚洲电影av| 久久精品在线| 亚洲一区二区伦理| 91久久久在线| 国产精品极品美女粉嫩高清在线| 午夜精品区一区二区三| 亚洲国产精品尤物yw在线观看| 亚洲伊人网站| 久久婷婷综合激情| 亚洲影音一区| 韩日视频一区| 国产精品丝袜久久久久久app| 欧美不卡激情三级在线观看| 午夜精品久久久久久久男人的天堂| 亚洲激情在线播放| 欧美高清不卡在线| 久久久久久久激情视频| 日韩视频专区| 91久久在线播放| 亚洲国产精品一区制服丝袜| 欧美日韩精品一区二区| 欧美二区在线| 久久性天堂网| 蜜臀91精品一区二区三区| 久久久国产一区二区三区| 午夜精品免费| 亚洲制服少妇| 亚洲小说欧美另类婷婷| 一区二区三区精密机械公司| 亚洲精品视频免费观看| 亚洲人成毛片在线播放| 亚洲国产成人精品久久久国产成人一区 | 亚洲视频在线观看视频| 99这里有精品| 一区二区国产精品| 日韩亚洲不卡在线| 日韩视频永久免费| 日韩亚洲视频| 99视频有精品| 亚洲视频在线观看一区| 午夜老司机精品| 久久国产精品毛片| 久久久欧美精品| 老司机久久99久久精品播放免费 | 久久蜜桃资源一区二区老牛| 久久夜色精品一区| 欧美 日韩 国产在线| 美女日韩欧美| 欧美国产精品中文字幕| 亚洲福利免费| 亚洲视频在线一区| 午夜精品一区二区三区在线| 亚洲欧美日本日韩| 久久久国产一区二区| 欧美高清视频在线| 欧美午夜精品理论片a级大开眼界| 国产精品videosex极品| 国产精品稀缺呦系列在线| 国产视频久久网| 亚洲激情校园春色| 亚洲欧美成人网| 久久久青草青青国产亚洲免观| 欧美国产精品久久| 亚洲一区在线看| 久久久久久亚洲精品中文字幕| 欧美成va人片在线观看| 国产精品第一区| 狠狠色丁香婷婷综合| 99国产精品视频免费观看一公开| 亚洲影音一区| 蜜臀va亚洲va欧美va天堂| 亚洲日本va午夜在线影院| 亚洲欧美日韩一区二区在线| 欧美在线视频一区| 欧美一进一出视频| 久久精品一本| 国产精品嫩草影院av蜜臀| 亚洲精品中文字幕在线| 午夜精品一区二区三区电影天堂|