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

Pencil.C++

更新速度可能會晚于http://blog.csdn.net/bilaopao

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  34 隨筆 :: 0 文章 :: 40 評論 :: 0 Trackbacks

    算法試卷第五題,看了下,根據題意對答案進行了一下擴展,用C++把算法寫了下。哎,不早了,該睡覺了。

題目:

5、(0-1背包問題)現有五個物品,其中(w1,w2,w3,w4,w5=(3,4,7,8,9),(v1,v2,v3,v4,v5)=(4,5,10,11,13),W=17.(wi表示物品重量,vi表示物品價值,W表示背包所能承受的總重量)。求背包能獲得最大價值的裝法

 1#include <stdio.h>
 2#include <vector>
 3#include <iostream.h>
 4using namespace std;
 5int knapsack(vector<double> w, vector<double> v,int W)
 6{
 7    int i=w.size();
 8    double *arg=new double[i];    //物品的單位重量價值
 9    //算出各物品的單位重量價值
10    for(int j=0;j<i;j++){
11        arg[j]=v[j]/w[j];
12    }

13    int *rank=new int[i];
14    for(int k=0;k<i;k++){//賦初始值,順序與物品下標相同
15        rank[k]=k;
16    }

17
18    for(int m=0;m<i;m++){
19
20        for(int n=m;n<i;n++){
21            if(arg[m]<arg[n]){
22                double t;
23                //轉換值
24                t=arg[m];
25                arg[m]=arg[n];
26                arg[n]=t;
27                //轉換下標
28                int temp1=rank[m];
29                int temp2=rank[n];
30                rank[m]=temp2;
31                rank[n]=temp1;
32            }

33        }

34    }

35    int *x=new int[i];//存放各物品放在包里的數量x[1]則為第二件物品放在包里的數量
36    for(int z=0;z<i;z++){
37        if(W/w[rank[z]]==0)continue;//判斷是否能翻進去 為0則說明當前物品超重
38        x[rank[z]]=W/w[rank[z]];//計算可以存放的物品數量
39        W=W-(W/w[rank[z]])*w[rank[z]];
40    }

41    cout<<"[";
42    for(int y=0;y<i;y++){
43        cout <<"x"<<y+1;
44        if(y+1!=i)cout <<",";
45    }

46    cout <<"]=";
47    cout <<"[";
48    for(y=0;y<i;y++){
49        cout <<x[y];
50        if(y+1!=i)cout <<",";
51    }

52    cout <<"]";
53    delete rank;
54    delete x;
55    delete arg;
56return 0;
57}

58
posted on 2009-06-19 00:00 Pencil.C++ 閱讀(3829) 評論(6)  編輯 收藏 引用 所屬分類: 數據結構與算法

評論

# re: 背包問題的算法分析(C++描述) 2009-06-19 09:29 Nobody
這是背包問題,不是01背包吧?  回復  更多評論
  

# re: 背包問題的算法分析(C++描述) 2009-06-19 11:27 pierre200328
先將性價比排序,然后從最大取起:
36 for(int z=0;z<i;z++){
37 if(W/w[rank[z]]==0)continue;//判斷是否能翻進去 為0則說明當前物品超重
38 x[rank[z]]=W/w[rank[z]];//計算可以存放的物品數量
39 W=W-(W/w[rank[z]])*w[rank[z]];
40 }
沒有回退?3個物品,最優不一定選1,有可能選2/3
感覺怪怪的。。理論上來說是不對  回復  更多評論
  

# re: 背包問題的算法分析(C++描述) 2009-06-19 12:59 Pencil.C++
@pierre200328
這個不用回退,因為37行的的判斷目的就是判斷當前的物品是否還能往背包里面放了。如果==0,那說明一個都放不進去了。所以不回退。


還有就是最優的問題w[rank[z]] 。 rank[z]這個數組里面保存的是物品標記。而且rank[0]保存的標記就是最大單位質量價值的標記。 rank[1]則是排在第二的。所以在這之前rank已經是經過比對排序的了。這個是18行冒泡算法的目的。

謝謝你的回復。  回復  更多評論
  

# re: 背包問題的算法分析(C++描述) 2009-06-19 14:10 絕影
感覺這個算法有點問題  回復  更多評論
  

# re: 背包問題的算法分析(C++描述) 2009-06-19 18:08 Pencil.C++
@絕影
確實有點問題。

有一種情況我沒有考慮到。

  回復  更多評論
  

# re: 背包問題的算法分析(C++描述) 2009-07-01 15:58 88
算法存在缺陷,可能不是最優解  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩视频在线第一区| 亚洲欧美日韩在线综合| 欧美日本在线一区| 久久人人爽爽爽人久久久| 欧美在线视频二区| 亚洲欧美在线高清| 欧美一区二区性| 久久精品国产一区二区三| 久久精品国产免费看久久精品| 欧美一级视频| 久久久综合视频| 老司机午夜精品视频在线观看| 女人色偷偷aa久久天堂| 欧美人成在线| 国产精品网站在线观看| 激情五月婷婷综合| 一本久久a久久精品亚洲| 性色av一区二区三区红粉影视| 久久午夜影视| 亚洲精选一区二区| 欧美影视一区| 免费永久网站黄欧美| 欧美视频在线观看免费| 国内精品视频一区| 一区二区三区不卡视频在线观看| 亚洲视频在线观看网站| 久久九九免费| 亚洲精品你懂的| 亚洲婷婷综合色高清在线| 欧美专区在线播放| 欧美日韩精品国产| 在线日韩欧美视频| 亚洲免费视频在线观看| 免费人成网站在线观看欧美高清 | 亚洲人成7777| 亚洲韩国青草视频| 午夜精品福利视频| 一区二区三区回区在观看免费视频| 欧美专区在线观看| 99国产精品国产精品久久| 久久午夜电影网| 国产欧美精品久久| 亚洲一二区在线| 91久久久久久| 久久久国产精品一区| 国产精品久久久久av免费| 亚洲国产婷婷香蕉久久久久久| 欧美在线一区二区三区| 一本色道久久综合亚洲精品高清| 欧美黑人国产人伦爽爽爽| 亚洲国产99| 另类专区欧美制服同性| 小处雏高清一区二区三区 | 欧美视频久久| 亚洲精品看片| 欧美大色视频| 欧美成人网在线| 日韩小视频在线观看专区| 欧美第一黄网免费网站| 久久蜜桃精品| 亚洲国产精品一区在线观看不卡 | 久久久久久久久久久久久9999| 一区二区日韩伦理片| 欧美日韩精品欧美日韩精品一| 99re视频这里只有精品| 亚洲精品日韩久久| 欧美日韩一区二区在线视频| 亚洲一二三四久久| 一区二区三区视频免费在线观看 | 欧美久久精品午夜青青大伊人| 亚洲第一天堂av| 欧美激情综合色| 欧美日韩国产首页| 亚洲一区在线视频| 亚洲欧美一区二区原创| 国产尤物精品| 亚洲成人资源网| 欧美精品色一区二区三区| 在线视频欧美一区| 亚洲午夜精品久久| 国产一区二区三区不卡在线观看| 久久久国产一区二区| 欧美a一区二区| 亚洲午夜精品一区二区| 性欧美xxxx大乳国产app| 一区二区在线不卡| 亚洲精品色图| 国产欧美日本| 看片网站欧美日韩| 欧美日韩爆操| 欧美一区二区三区日韩| 榴莲视频成人在线观看| 国产精品欧美激情| 亚洲视频在线免费观看| 国产日本欧美一区二区三区| 久久久另类综合| 欧美激情国产高清| 欧美在线免费观看亚洲| 欧美国产精品久久| 性色av一区二区三区| 欧美.www| 久久成人亚洲| 欧美日韩性生活视频| 久久九九免费视频| 欧美日韩一区二区三区四区在线观看| 性18欧美另类| 欧美日韩www| 免费视频一区二区三区在线观看| 欧美电影免费观看高清完整版| 久久免费国产精品1| 欧美精品一二三| 亚洲第一精品夜夜躁人人爽| 亚洲国产小视频在线观看| 美国三级日本三级久久99| 99视频一区二区| 久久久久国产精品午夜一区| 亚洲天堂成人在线观看| 久久免费少妇高潮久久精品99| 亚洲欧美高清| 欧美日韩亚洲一区二区三区在线| 老鸭窝毛片一区二区三区| 国产精品美女www爽爽爽视频| 亚洲国产高清一区| 一区视频在线| 午夜久久久久久| 亚洲午夜一级| 国产视频一区免费看| 欧美一区三区三区高中清蜜桃| 欧美综合国产精品久久丁香| 亚洲美女少妇无套啪啪呻吟| 蜜臀va亚洲va欧美va天堂| 麻豆91精品| 韩国亚洲精品| 欧美在线|欧美| 亚洲欧美日韩精品一区二区 | 欧美在线二区| 国产精品你懂得| 中文一区在线| 性欧美videos另类喷潮| 国产精品毛片va一区二区三区 | 久久亚洲私人国产精品va| 国产欧美日韩一区二区三区| 亚洲欧美日韩一区二区三区在线| 午夜视频在线观看一区二区| 国产精品性做久久久久久| 亚洲欧美日韩精品久久| 欧美一区二区三区视频免费播放 | 国产人成精品一区二区三| 亚洲午夜久久久久久久久电影院 | 国产午夜精品在线观看| 中文在线资源观看网站视频免费不卡 | 欧美岛国激情| 99国产精品久久久久久久成人热| 亚洲一区二区成人| 国产欧美日本一区二区三区| 久久国产精品久久w女人spa| 免费在线一区二区| 亚洲激情av在线| 欧美日本不卡| 亚洲自拍偷拍麻豆| 麻豆九一精品爱看视频在线观看免费 | 午夜精品久久久久久99热| 国产精品免费在线| 亚洲欧美综合| 欧美激情亚洲国产| 亚洲在线中文字幕| 国内精品免费在线观看| 久久久久久久久久久成人| 亚洲欧洲一区二区三区在线观看| 一本色道久久加勒比88综合| 免费欧美在线| 欧美一区高清| 国产精品久久久久毛片软件| 欧美一区二区啪啪| 在线不卡视频| 欧美久久久久| 亚洲视频在线观看网站| 久久亚洲电影| 亚洲美女啪啪| 国产一区二区三区久久久久久久久| 久久精品国产亚洲a| 亚洲激情在线观看视频免费| 欧美专区在线观看| 99re热这里只有精品免费视频| 国产综合av| 国产精品嫩草影院av蜜臀| 欧美不卡激情三级在线观看| 午夜视频久久久久久| 亚洲国产精品999| 欧美一区二区精品在线| 91久久在线| 国产亚洲精品成人av久久ww| 欧美国产日韩一区二区| 中文在线资源观看网站视频免费不卡| 亚洲校园激情| 国产一区二区欧美| 亚洲激情视频在线观看| 性亚洲最疯狂xxxx高清| 亚洲黄色影片| 激情一区二区三区|