• <em id="ukelm"><acronym id="ukelm"></acronym></em>
    <button id="ukelm"></button>

  • <em id="ukelm"><ruby id="ukelm"></ruby></em>
  • 新聞分類

    產品分類

    聯系我們

    深圳市豐茂手袋皮具有限公司

    電話:0755-27378729

    郵箱:bfm@szbfm.com

    傳真:0755-27378857

    地址:深圳市寶安區福永街道鳳凰第一工業區A31棟

    網址:www.penacasamadridista.com

    關于三種背包的問題

    您的當前位置: 首 頁 >> 新聞中心 >> 技術知識

    關于三種背包的問題

    發布日期:2019-06-29 作者:admin 點擊:

    關于三種背包的問題

    【摘要】有人說,困難的題目都是由簡單的題目疊加而來的。這句話是否公理暫且存之不論,但它在本講中已經得到了充分的體現。本來01背包、完全背包、多重背包都不是什么難題,但將它們簡單地組合起來以后就得到了這樣一道一定能嚇倒不少人的題目。但只要基礎扎實,領會三種基本背包問題的思想,就可以做到把困難的題目拆分成簡單的題目來解決。

    如果將P01、P02、P03混合起來。也就是說,有的物品只可以取一次(01背包),有的物品可以取無限次(完全背包),有的物品可以取的次數有一個上限(多重背包)。應該怎么求解呢?
    背包混合

    商務包公文包考慮到在P01和P02中Z后給出的偽代碼只有一處不同,故如果只有兩類物品:一類物品只能取一次,另一類物品可以取無限次,那么只需在對每個物品應用轉移方程時,根據物品的類別選用順序或逆序的循環即可,復雜度是O(VN)。偽代碼如下:
    for i=1..N
    if 第i件物品是01背包
    for v=V..0
    f[v]=max{f[v],f[v-c]+w};
    else if 第i件物品是完全背包
    for v=0..V
    f[v]=max{f[v],f[v-c]+w};
    再加上多重背包
    如果再加上有的物品Z多可以取有限次,那么原則上也可以給出O(VN)的解法:遇到多重背包類型的物品用單調隊列解即可。但如果不考慮超過NOIP范圍的算法的話,用P03中將每個這類物品分成O(log n)個01背包的物品的方法也已經很優了。
    小結
    有人說,困難的題目都是由簡單的題目疊加而來的。這句話是否公理暫且存之不論,但它在本講中已經得到了充分的體現。本來01背包、完全背包、多重背包都不是什么難題,但將它們簡單地組合起來以后就得到了這樣一道一定能嚇倒不少人的題目。但只要基礎扎實,領會三種基本背包問題的思想,就可以做到把困難的題目拆分成簡單的題目來解決。



    本文網址:http://www.penacasamadridista.com/news/404.html

    相關標簽:商務包公文包

    Z近瀏覽:

    相關產品:

    在線客服
    分享 一鍵分享
    歡迎給我們留言
    請在此輸入留言內容,我們會盡快與您聯系。
    姓名
    聯系人
    電話
    座機/手機號碼
    郵箱
    郵箱
    地址
    地址
    精品国产免费一区二区三区,无翼乌全彩3d工口里番琉璃神社,大量情侣网站,免费人成在线观看视频平台
    东平县咖啡有限公司 无棣县艺术有限公司 浦江县蔬菜有限公司 浦江县坚果有限公司 博兴县广告有限公司 商洛市木炭有限公司
    延安市设计有限公司 兰州市培训有限公司 广安市可可有限公司 仙居县坚果有限公司 阳谷县干果有限公司 马尔康市服装有限公司
    德阳市动植物种苗有限公司 鄄城县仪器有限公司 酒泉市干果有限公司 绵阳市动植物种苗有限公司 惠民县能源有限公司 泸州市水果有限公司