自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

kyriesnow的专栏

我的世界,坠入深渊。

  • 博客(5)
  • 收藏
  • 关注

原创 限定条件不止一种的背包问题

对于正常的背包问题,只有一个限定条件——背包容量不超过多少,而有些背包问题有多重限定条件,比如NASA的食物计划这道题,有体积和质量这两个限定条件。 对于这种问题,其实是和正常的背包问题是差不多的,只需要多加一层循环而已。 下面附上这道题的代码: #include #include #define MAXL 401 using namespace std; int dp[MAXL][M

2015-03-14 09:45:42 4080

原创 最小公约数和最大公倍数模板

int gcd(int m,int n)//最大公约数,辗转相除法 { do { r=m%n; m=n; n=r; } while(n); return m; } ------------------------------------------------ int gcd(int m,

2015-03-14 09:26:02 331

原创 浅谈分组背包

分组背包,由基础背包演化而来的一种情况。 具体问题是这样的。具体问题是这样的。一个容量为V的背包,还有若干组物品,每组包含若干物品,这些物品各不相同,而且体积w和价值p各不相同。组内的物品相冲突。求出能在不超过V的情况下尽可能的使价值最大。 乍一看好像很难的样子,其实仔细想想很简单,这种问题完全可以用01背包解决。 对于分组背包,可以这样想:虽然分成很多组,但只能选一个,或者不

2015-03-14 09:21:51 2805 1

原创 浅谈多重背包

多重背包,基础背包问题之三。 具体问题是这样的。一个容量为V的背包,还有一些物品(每个物品有具体的数量c),这些物品的体积w和价值p各不相同。求出能在不超过V的情况下尽可能的使价值最大。 对于多重背包问题,可以根据每个物品的数量分解成两种情况: 1.当c >= V / w时,相当于物品可以无限使用,即转化为完全背包求解。 2.当c 但是上面这种方法的时间复杂度为

2015-03-14 09:20:55 914

原创 浅谈01背包和完全背包

01背包,基础背包问题之一。 具体问题是这样的。一个容量为V的背包,还有一些物品(每个物品只有一个),这些物品的体积w和价值p各不相同。求出能在不超过V的情况下尽可能的使价值最大。 对于01背包问题,用动态规划的思想很简单,只需考虑子问题的两种情况: 如果i个物品放入,那么就转化为前i-1个装入j-w[i],价值为dp[i-1][j-w[i]]+p[i]。 如果i个物品不放

2015-03-14 09:15:40 452

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除