亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? bag.c

?? 在0 / 1背包問題中
?? C
字號:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

//goods是一個或多個物品的重量和價值

typedef struct goods
{
  int weight;
  int value;
} goods;

//用來定義一個queryList數組

//數組中的每個元素定義一趟需要記錄的數據

typedef struct queryList
{
  goods *subResult; //一趟需要記錄的數據

  int end; //指示該趟數據的最后一個元素

} queryList;

queryList* dknap(goods *Goods, int count, int capacity)
{
  int i, j, next, pre, index, k;
  queryList *ql;
  goods cur;
  ql = (queryList *)malloc(sizeof(queryList)*count);
  ql[0].subResult = (goods*)malloc(sizeof(goods));
  ql[0].end = 0;
  ql[0].subResult->weight = 0;
  ql[0].subResult->value = 0;

  for(i=1;i<count;i++)
  {
    pre = 0;
    index = 0;
    ql[i].subResult = (goods*)malloc(sizeof(goods)*(ql[i-1].end+1)*2);
    cur.weight = ql[i-1].subResult[0].weight + Goods[i-1].weight;
    cur.value = ql[i-1].subResult[0].value + Goods[i-1].value;
    next = 1;


    //合并生成新的一趟需要記錄的數據, 類似于merge sort
    while (pre<ql[i-1].end+1)
    {
      if (cur.weight>ql[i-1].subResult[pre].weight)
        if (cur.value <= ql[i-1].subResult[pre].value) //拋棄新生成元素
        {
          cur.weight = ql[i-1].subResult[next].weight + Goods[i-1].weight;
          cur.value = ql[i-1].subResult[next].value + Goods[i-1].value;
          next++;
        }
        else //插入舊元素
        {
          ql[i].subResult[index].weight = ql[i-1].subResult[pre].weight;
          ql[i].subResult[index].value = ql[i-1].subResult[pre].value;
          pre++;
          index++;
        }
      else
        if (cur.weight<ql[i-1].subResult[pre].weight)
          if (cur.value >= ql[i-1].subResult[pre].value) //拋棄舊元素
            pre++;
          else  //插入新生成元素
          {
            ql[i].subResult[index].weight = cur.weight;
            ql[i].subResult[index].value = cur.value;
            index++;
            cur.weight = ql[i-1].subResult[next].weight + Goods[i-1].weight;
            cur.value = ql[i-1].subResult[next].value + Goods[i-1].value;
            next++;
          }
        else
          if (cur.value >= ql[i-1].subResult[pre].value) //拋棄舊元素
            pre++;
          else  //拋棄新生成元素
          {
            cur.weight = ql[i-1].subResult[next].weight + Goods[i-1].weight;
            cur.value = ql[i-1].subResult[next].value + Goods[i-1].value;
            next++;
          }
    }
    //插入剩余的新生成元素
    for(j=next-1;j<ql[i-1].end+1;j++)
    {
      if (ql[i-1].subResult[j].weight + Goods[i-1].weight > capacity)
        break;
      ql[i].subResult[index].weight = ql[i-1].subResult[j].weight + Goods[i-1].weight;
      ql[i].subResult[index].value = ql[i-1].subResult[j].value + Goods[i-1].value;
      index++;
    }
   
    ql[i].end=index-1;
    printf("i=%d\n", i);
    for(j=0;j<ql[i].end+1;j++)
      printf("(%d, %d)\n", ql[i].subResult[j].value, ql[i].subResult[j].weight);
  }

  finalResult(ql, Goods, count, capacity);
  for(i=0;i<count;i++)
    free(ql[i].subResult);
  free(ql);
  return ql;
  
}


//輸出最終的取舍情況
int finalResult(queryList* ql, goods* Goods, int count, int capacity)
{
  int i, j, k;
  for(i=count-1;i>=0;i--)
  {
    k=ql[i].end;
    while (k>=0)
    {
      if (ql[i].subResult[k].weight>capacity)
        k--;
      else break;
    }
    j=k;
    while (j>=0)
    {
      if (ql[i].subResult[j].weight+Goods[i].weight>capacity)
        j--;
      else break;
    }
    
    if (k>=0 && j<0)
      printf("a[%d]=%d\n", i, 0);
    else if (k<0)
    {
      printf("unsatifitable\n");
      return -1;
    }
    else 
    {
      if (ql[i].subResult[k].value>=ql[i].subResult[j].value+Goods[i].value)
        printf("a[%d]=%d\n", i, 0);
      else
      {
        printf("a[%d]=%d\n", i, 1);
        capacity = capacity - Goods[i].weight;
      }
    }
  }
}

int main()
{
  goods Goods[] = {{2, 1}, {3, 2}, {4, 5}};
  dknap(Goods, sizeof(Goods)/sizeof(Goods[0]), 6);
  //goods Goods[] = {{100, 100}, {50, 50}, {20, 20}, {10, 10}, {7, 7}, {3, 3}};
  //dknap(Goods, sizeof(Goods)/sizeof(Goods[0]), 165);

  
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久免费的精品国产v∧| 欧美色电影在线| 捆绑变态av一区二区三区| 亚洲一区二区在线播放相泽| 亚洲欧洲精品一区二区三区| 国产丝袜在线精品| 欧美国产日韩精品免费观看| 中文字幕av一区二区三区免费看 | 日韩欧美国产成人一区二区| 欧美老肥妇做.爰bbww| 欧美亚洲一区二区在线| 欧美性色aⅴ视频一区日韩精品| 在线免费观看日本一区| 欧美日韩一区三区四区| 日韩欧美中文一区二区| 久久综合久久鬼色中文字| 中文字幕av一区二区三区高| 国产精品美女久久久久aⅴ国产馆| 国产精品日韩精品欧美在线| 亚洲日本青草视频在线怡红院| 一区二区三区免费网站| 视频一区二区国产| 国产在线精品视频| 99久久精品一区二区| 欧美揉bbbbb揉bbbbb| 日韩欧美国产精品| 亚洲天堂成人网| 麻豆专区一区二区三区四区五区| 国产在线视视频有精品| 91在线高清观看| 欧美精品一二三四| 久久久不卡影院| 亚洲主播在线播放| 精品一区二区三区在线播放视频 | 欧美日韩大陆在线| 国产清纯在线一区二区www| 一区二区三区资源| 国产乱淫av一区二区三区| 欧洲激情一区二区| 精品久久久久久最新网址| 亚洲国产成人私人影院tom| 亚洲成人动漫在线观看| 国产999精品久久久久久| 欧美性xxxxxx少妇| 国产日韩影视精品| 免费高清不卡av| 色狠狠一区二区| 精品国产亚洲在线| 亚洲成人av在线电影| 成a人片亚洲日本久久| 日韩精品一区二区在线观看| 一区二区三区高清| gogo大胆日本视频一区| 日韩欧美中文字幕制服| 亚洲va国产天堂va久久en| 国产不卡高清在线观看视频| 欧美一区二区福利视频| 一区二区三区**美女毛片| 成人免费视频播放| 久久久青草青青国产亚洲免观| 舔着乳尖日韩一区| 色婷婷综合久久久中文一区二区| 久久亚洲影视婷婷| 精品制服美女丁香| 6080国产精品一区二区| 亚洲激情一二三区| 91蜜桃在线观看| 亚洲欧洲一区二区三区| 国产精品456露脸| 精品成人私密视频| 精品一区二区国语对白| 91麻豆精品91久久久久同性| 天使萌一区二区三区免费观看| 色天天综合久久久久综合片| 亚洲天天做日日做天天谢日日欢| 欧美日韩亚洲国产综合| 亚洲一区二区三区四区在线| 色婷婷综合久久久久中文一区二区| 国产精品全国免费观看高清| 成人免费毛片嘿嘿连载视频| 中文字幕第一区第二区| 成人app在线观看| 中文字幕一区二区三区蜜月| 99久久久免费精品国产一区二区 | 91在线国产观看| 亚洲日本青草视频在线怡红院| aaa欧美日韩| 一区二区三区四区视频精品免费 | 亚洲成人免费在线| 欧美精品日韩一本| 久久成人18免费观看| 久久综合色天天久久综合图片| 国产裸体歌舞团一区二区| 久久青草国产手机看片福利盒子| 国产综合成人久久大片91| 久久久国产一区二区三区四区小说 | 色综合久久综合中文综合网| 亚洲香蕉伊在人在线观| 日韩视频免费观看高清完整版在线观看| 日本aⅴ免费视频一区二区三区| 欧美变态tickle挠乳网站| 成人综合在线观看| 亚洲va欧美va国产va天堂影院| 日韩免费性生活视频播放| 国产麻豆91精品| 亚洲综合视频网| 精品国产91久久久久久久妲己 | 舔着乳尖日韩一区| 久久中文娱乐网| 91麻豆精品在线观看| 蜜乳av一区二区三区| 国产精品乱码一区二区三区软件| 日本福利一区二区| 经典三级一区二区| 亚洲一区在线免费观看| 国产日韩精品一区二区浪潮av | 韩国女主播一区| 亚洲免费资源在线播放| 欧美mv和日韩mv的网站| 91女厕偷拍女厕偷拍高清| 蜜臀va亚洲va欧美va天堂| 亚洲精品乱码久久久久久久久| 精品国产一区a| 欧美日韩一级二级| 97精品久久久午夜一区二区三区| 麻豆91免费看| 亚洲国产你懂的| 亚洲视频免费在线| 久久久国际精品| 欧美mv日韩mv亚洲| 欧美美女激情18p| 色婷婷一区二区三区四区| 成人午夜视频在线| 狠狠色丁香婷婷综合| 视频一区二区三区中文字幕| 亚洲三级在线免费观看| 国产精品久线在线观看| 久久久久久电影| www日韩大片| 日韩欧美成人激情| 日韩三级高清在线| 这里是久久伊人| 欧美色老头old∨ideo| 91国偷自产一区二区三区观看| 成人激情动漫在线观看| 丁香婷婷深情五月亚洲| 国产福利一区在线观看| 久久精品av麻豆的观看方式| 亚洲国产精品一区二区www在线| 亚洲美女视频在线| 夜夜操天天操亚洲| 亚洲精品乱码久久久久久黑人| 亚洲欧美激情小说另类| 亚洲女人****多毛耸耸8| 国产精品不卡一区| 亚洲免费观看高清| 尤物在线观看一区| 一区二区三区久久| 亚洲国产中文字幕| 免费欧美在线视频| 久久66热re国产| 国产激情精品久久久第一区二区| 国产高清成人在线| 97精品国产露脸对白| 欧美系列在线观看| 欧美一区二区福利在线| 精品国产乱码久久久久久久| 国产欧美一二三区| 亚洲日本乱码在线观看| 香蕉加勒比综合久久| 久久不见久久见免费视频7| 国产一区二区0| 成人美女视频在线看| 91麻豆123| 日韩一区二区三区观看| 精品99一区二区三区| 中文字幕综合网| 三级影片在线观看欧美日韩一区二区| 久久精品av麻豆的观看方式| 成人中文字幕在线| 欧美亚洲一区二区在线观看| 日韩精品最新网址| 亚洲丝袜精品丝袜在线| 午夜一区二区三区视频| 国产在线一区二区综合免费视频| av激情成人网| 69av一区二区三区| 中文字幕不卡一区| 日本91福利区| 色综合久久久网| 欧美成人性战久久| 亚洲欧美一区二区三区孕妇| 午夜精品视频在线观看| 国产成人高清在线| 欧美久久久一区| 国产精品伦理一区二区| 久久精品二区亚洲w码| 91成人看片片| www国产成人免费观看视频 深夜成人网| 亚洲欧洲一区二区三区|