Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1907107
  • 博文数量: 211
  • 博客积分: 464
  • 博客等级: 下士
  • 技术积分: 3794
  • 用 户 组: 普通用户
  • 注册时间: 2011-01-24 18:25
个人简介

阿弥陀佛

文章分类

全部博文(211)

文章存档

2020年(2)

2019年(3)

2018年(5)

2017年(6)

2016年(10)

2015年(9)

2014年(73)

2013年(90)

2012年(13)

分类: C/C++

2013-07-19 17:34:45

钢筋分割问题
长度i对应价格p(i)
那么给定长度i,如何分割才能够使得收益最大呢?
动态规划是将问题划分子问题然后求解,所以动态规划的前提是问题是可分解成子问题的。

由于每一节都有两种情况分,或者部分,所以总共有2^(n-1)次方的分解方法。
解法一:
  
 cutFc(int n,p)
{
   int q;
   if n == 0
        return 0;
    else 
     q=0;
      for(i=1;i<=n;i++)
          q = max(q,p[i]+cutFc(n-i,p));
    return q;
}
解法二:
   带备忘录的算法解决方案,只是加了一个变量的存储功能就让整个效率高了起来:
 cutFc(int n,p,int *r)
{
   int q;
    if(r[n]>=0)

         return r[n];
     if n == 0

        return 0;
    else 
     q=0;
      for(i=1;i<=n;i++)
          q max(q,p[i]+cutFc(n-i,p));
    r[n] = q;

    return q;
}
阅读(1292) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~