DP-2dimention

97. Interleaving String

Given a list of unique words. Find all pairs of distinct indices(i, j)
in the given list, so that the concatenation of the two words, i.e.words[i] + words[j]
is a palindrome.
Example 1:Givenwords
=["bat", "tab", "cat"]
Return[[0, 1], [1, 0]]
The palindromes are["battab", "tabbat"]

Example 2:Givenwords
=["abcd", "dcba", "lls", "s", "sssll"]
Return[[0, 1], [1, 0], [3, 2], [2, 4]]
The palindromes are["dcbaabcd", "abcddcba", "slls", "llssssll"]


思考

  • 理解题意
    这道题目的特点是要在两个字符串s1、s2里面轮流找slice,交织拼接成s3
    注意的地方是sclice必须是连续的,比如下面的情况就不合理:
    s1 : sliceA, sliceB, sliceC
    s2 : sliceD, sliceE
    s3 = A D C E B, 因为这里虽然满足了 s1 s2的slice是轮流出现的,
    但是对于s1 来说,slice出现的次序是 : ACB, 不是顺序的ABC,所以不满足“交织”这个概念
    正确的一个列子是:s3 = A D B E C

思路

  • 怎么满足“交替出现”---> 2 个方向
  • 找得到的时候怎么样?找不到的时候怎么样?
    (1)回溯 ?(back until true, and restart again)
    (2)DP ?(go froward because you know you are the outcome of your previous ones)

策略

  1. 回溯的思路【较为直观,实现繁琐,辅助变量较多】
  • 两个指针,代表在s1, s2中移动到下一个待匹配字符的位置
  • 因为是轮流出现,所以需要一个 count 用奇偶来表示whose turn
  • 找不到的话需要退回去,所以需要一个path来记录前面的拼接方式
  • 加入“贪心”的小策略,在s1或者s2中单独找的时候,是一直找到最长的那个匹配字符,如果不行,需要回退的时候,长度-1,如果长度已经是1了,就需要在path中弹出。这个过程需要更新count
  1. dp的思路【相对抽象,更加简洁,快】
  • “两个方向” --> matrix 的两个维度
  • 要在s1,s2中轮流找 -->
if(  (str1[i-1]==str3[i+j-1] && map[i-1][j]==true)   ||
      (str2[j-1]==str3[i+j-1] && map[i][j-1]==true)   )
        map[i][j] = true;
// 正因为是交替出现,所以str1和str3匹配的时候,
// 要看前一个str2是不是和str3匹配。反之亦然。
  • 如何“记忆化”搜索?
  • 怎么提高速度?
    • 剪枝?
    • 2 列代替整个矩阵
    • 编程语言上的优化技巧
  • 要注意的地方
    dp[len1+1][len2+1], 索引str1和str2的时候要记得-1

实现

具体代码

    public boolean isInterleave(String s1, String s2, String s3) {
        if(s1==null || s2==null || s3==null)
            return false;
        if(s1.length() + s2.length() != s3.length())
            return false;
        
        int len1 = s1.length();
        int len2 = s2.length();
        boolean[][] map = new boolean[len1+1][len2+1];
        
        map[0][0] = true;
        
        char[] str1 = s1.toCharArray();
        char[] str2 = s2.toCharArray();
        char[] str3 = s3.toCharArray();
        
        for(int i=1; i<len1+1; i++)
        {
            if(str1[i-1]==str3[i-1] && map[i-1][0]==true )
                map[i][0] = true;
            else
                break;
        }
        
        for(int j=1; j<len2+1; j++)
        {
            if(str2[j-1]==str3[j-1] && map[0][j-1]==true)
                map[0][j] = true;
            else
                break;
        }
        
        for(int i=1; i<len1+1; i++)
        {
            for(int j=1; j<len2+1; j++)
            {
                if( (str1[i-1]==str3[i+j-1] && map[i-1][j]==true) ||
                    (str2[j-1]==str3[i+j-1] && map[i][j-1]==true) )
                    map[i][j] = true;
            }
        }
        return map[len1][len2];
    }

优化

  • 怎么提高速度?
    • 剪枝?
      @ wait for implement
    • 2 列代替整个矩阵
      @ wait for implement
    • 编程语言上的优化技巧
      (1) 先把 String 转成 char[], 以后每次操作都对char[]进行,从9ms到8ms
      (2) 利用boolean[][] 初始化的时候默认为false, 所以初始化的时候一旦不是true就break, 另外就是对map[i][j]更新的时候只对true进行更新

小收获

  1. 多种可能性的路径探索,如果能够记忆化,就不一定要回溯
  2. 两个方向进行,可以抽象成矩阵的两个维度,或许会比用两个指针更方便。

To do list

  1. dp还有很多可以优化的地方,要继续总结。
  2. 尝试把以前做过的dp题都进行优化。

参考: http://blog.csdn.net/u011095253/article/details/9248073
http://www.cnblogs.com/boring09/p/4239255.html
http://46aae4d1e2371e4aa769798941cef698.devproxy.yunshipei.com/sunliymonkey/article/details/48165711

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

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,719评论 0 33
  • 动态规划(Dynamic Programming) 本文包括: 动态规划定义 状态转移方程 动态规划算法步骤 最长...
    廖少少阅读 3,252评论 0 18
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,560评论 18 399
  • 1. string对象的定义和初始化以及读写 string s1; 默认构造函数,s1为空串 string s2(...
    阔爷阅读 418评论 0 0
  • 读罢《群山回唱》,就能明白胡赛尼叙事安排的苦心――那一个个看似分散,跨越时间、国度而有有着若有似无联系的故事,可不...
    木徐阅读 539评论 3 0