数据结构&算法之动态规划(深度优先遍历)

最近在看关于数据结构系列知识点,然后遇到一个动态规划相关的题目——邮票规划。
首先先介绍下关于DPS,也就是深度优先遍历算法吧。

深度优先遍历

深度优先遍历,从初始访问结点出发,我们知道初始访问结点可能有多个邻接结点,深度优先遍历的策略就是首先访问第一个邻接结点,然后再以这个被访问的邻接结点作为初始结点,访问它的第一个邻接结点。总结起来可以这样说:每次都在访问完当前结点后首先访问当前结点的第一个邻接结点。

一句话的事情:优先进行纵向访问,而不是广度优先遍历的横向进行访问

动态规划相关知识点

动态规划算法的基本思想是:将带求解的问题分解成若干个相互联系的子问题,先求解子问题,然后从这些子问题的解中得到原问题的解;对于重复出现的子问题,只在第一次遇到的时候对它进行求解,并把答案保存起来,避免重复求解。该思想与记忆化搜索类似,即将计算步骤中的过程保存下来,避免重复运算

要点

  • 动态规划适用于这些子问题不是独立的情况,也就是各子问题包含公共子问题
  • 需要记录每个子问题求解的问题结果,以供其他问题进行解决

相关步骤

  1. 划分阶段:按照问题的时间或空间特征,把问题分为若干个阶段。在划分阶段时,注意划分后的阶段一定要是有序的或者是可排序的,否则问题就无法求解。
  2. 确定状态和状态变量:注意状态必须满足无后效性。
  3. 确定决策:找到子问题是进行动态规划的重要一步。动态规划和递推更多应考虑本问题由哪些已解决子问题构成,而不是考虑本问题对将来哪些问题有贡献。
  4. 确定边界条件,写出状态转移方程

具体事例

问题描述
  给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤13)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1~MAX之间的每一个邮资值都能得到。

例如,N=3,K=2,如果面值分别为1分、4分,则在1分~6分之间的每一个邮资值都能得到(当然还有8分、9分和12分);如果面值分别为1分、3分,则在1分~7分之间的每一个邮资值都能得到。可以验证当N=3,K=2时,7分就是可以得到的连续的邮资最大值,所以MAX=7,面值分别为1分、3分。
输入格式
  一行,两个数N、K
输出格式
  两行,第一行升序输出设计的邮票面值,第二行输出“MAX=xx”(不含引号),其中xx为所求的能得到的连续邮资最大值。
样例输入
3 2
样例输出
1 3
MAX=7

当看到这个问题我们藉由之前的理论来具体分析下。

动态规划
  • 子问题
    • 是否选择面值各大的邮票呢,这里显示选择只能“是”或者“否”
  • 最优子结构
    • 当然同理,连续邮票的面值在每个值下都成立,这样就构成了结构。
  • 边界
    邮票的种类数目

当然有了上面的几点,我们试着写下该方式的转化方程,假如n代表邮票总共类别,i代表邮票总面值,stamp[i]代表邮票所属值大小,dp[i]代表凑齐 i 面值最少需要多少邮票,Dp(int position)代表几种类别的所能组成邮票值。

  • 当i >= stamp[k] && dp[i] > dp[i - stamp[k]] + 1,则 dp[i] = dp[i - stamp[k]] + 1;就是说取最大的那个。
    • 当dp[i]>n,Dp(position)=i,
    • 当dp[i]<n,Dp(postion)=-1;就是说无意义
DPS的使用
  • deep深度——由于每个邮件的类别数目难以确定,所以需要以邮票数目为DPS的递归深度deep)
  • 中止条件——当确定最大连续能取得值maxm,那么新加入的物品价值一旦大于maxm+1,显然就会出现断层,所以可以以maxm+1为枚举上界,然后这样进行下一层的dfs。

附上java代码:

import java.util.Arrays;
import java.util.Scanner;

public class Main {
    static int N=500;
    static  int n,m,ans;
    static  int a[]=new int[N+1];
    static  int b[]=new int[N+1];
    static  int f[]=new int[N+1];
    public static void main(String[] args) {
        int i,j,k;
        Scanner scanner =new Scanner(System.in);
        n=scanner.nextInt();
        m=scanner.nextInt();
        a[1]=1;
        dfs(1);
        for(i=1;i<=m;i++)
            System.out.printf("%d ",b[i]);
        System.out.printf("\nMAX=%d\n",ans);
    }
    static void dfs(int deep)
    {
        int i,j,uplimit;
        Arrays.fill(f,0x3f);
        f[0]=0;
        for(uplimit=1;uplimit<=N;uplimit++)
        {
            for(i=1;i<=deep&&a[i]<=uplimit;i++)
                f[uplimit]=Math.min(f[uplimit],f[uplimit-a[i]]+1);
            if(f[uplimit]>n)
            {
                uplimit--;
                if(uplimit>ans)
                {
                    ans=uplimit;
                    for(i=1;i<=deep;i++)
                        b[i]=a[i];
                }
                break;
            }
        }
        if(deep==m)return ;
        for(i=uplimit+1;i>a[deep];i--)
        {
            a[deep+1]=i;
            dfs(deep+1);
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容

  • 动态规划(Dynamic Programming) 本文包括: 动态规划定义 状态转移方程 动态规划算法步骤 最长...
    廖少少阅读 3,256评论 0 18
  • 课程介绍 先修课:概率统计,程序设计实习,集合论与图论 后续课:算法分析与设计,编译原理,操作系统,数据库概论,人...
    ShellyWhen阅读 2,252评论 0 3
  • 因为之前就复习完数据结构了,所以为了保持记忆,整理了一份复习纲要,复习的时候可以看着纲要想具体内容。 树 树的基本...
    牛富贵儿阅读 6,763评论 3 10
  • 树形动态规划,顾名思义就是树+DP,先分别回顾一下基本内容吧:动态规划:问题可以分解成若干相互联系的阶段,在每一个...
    Mr_chong阅读 1,464评论 0 2
  • VisuAlgo!一,Date Structure的核心技术是分解和抽象二,基本概念和常用术语 三,逻辑结构1,逻...
    斜杠青年许晏铭阅读 867评论 0 0