设为首页 收藏本站
查看: 1771|回复: 0

[经验分享] 华为OJ之最长公共子序列

[复制链接]

尚未签到

发表于 2017-7-10 11:18:13 | 显示全部楼层 |阅读模式
  题目描述:
  对于两个给定的字符串,给出他们的最长公共子序列。
  题目分析:
  1,在之前的博文(http://www.cnblogs.com/yonguo123/p/6711360.html)中我们讨论了最长公共子串的问题,当时也指出最长公共子串其实就是最长公共子序列的一种特殊情况,那么今天我们就来一起研究一下最长公共子序列的求解;
  2,最长公共子序列的定义这里不再赘述,和之前的最长公共子串一样,我们这次仍然采用动态规划和回溯的思想来解决;
  3,我们假设输入为str1, str2, 首先来通过动态规划获取最大最序列的长度:
  3-1,构建一个二维数组tempMatrix,维度为(str1.length + 1), (str2.length + 1);
  3-2,temp[j]的含义:str1.subString(0, i)和str2.subString(0, j)的最长公共子序列(注意理解这个数组的含义)的长度;
  3-3,显然temp[j] == 0, 当i == 0 || j == 0;
  3-4,否则,当 str1.charAt(i - 1) == str2.charAt(j - 1)时,temp[j] = temp[i - 1][j - 1] + 1, 否则temp[j] == max{temp[i, j - 1], temp[i - 1, j]}(具体原因大家自己思考一下,可以从新加入的两个尾字符是否会出现在新的LCS中来思考);
  4,已经构建好了tempMatix矩阵,实际上tempMatrix[str1.length][str2.length]就是LCS的长度了,而且tempMatrix也保存了必要的回溯信息,下面我们继续构建一个String[][] flagMatrix = new String[str1.length][str2.length], 规则如下:
DSC0000.png

  可能会有同学对这个左上,上,左的取值有疑问,请看下面这张回溯图:
DSC0001.png

  实际上回溯时具体的方向与我们对于坐标的选取是有关系的,所以大家在写代码之前,应该先把坐标方向规定好。之后的工作就是利用flagMatrix来逐步回溯,详细的实现细节见代码。
  5,如果还有其它更好的想法,欢迎大家与我交流^-^
  具体代码(Java实现):



import java.util.Scanner;

public class LCSequence {
     public static void main(String[] args) {
         String[] paras = getInput();
         System.out.println(getLongestSubsequence(paras[0], paras[1]));
     }
     
     public static String[] getInput() {
         Scanner reader = new Scanner(System.in);
         String[] paras = new String[2];
         paras[0] = reader.nextLine();
         paras[1] = reader.nextLine();
         reader.close();
         return paras;
     }
     
     public static String[][] getGenerationMatirx(String str1, String str2) {
         int[][] temp = new int[str1.length() + 1][str2.length() + 1];
         String[][] flag = new String[str1.length() + 1][str2.length() + 1];
         for (int i = 0; i <= str1.length(); i ++) {
             temp[0] = 0;
         }
         for (int i = 0; i <= str2.length(); i ++) {
             temp[0] = 0;
         }
         //迭代获取最长公共子序列的生成矩阵
         for (int i = 1; i <= str1.length(); i ++) {
             for (int j = 1; j <= str2.length(); j ++) {
                 if (str1.charAt(i - 1) == str2.charAt(j - 1)) {
                     temp[j] = temp[i - 1][j - 1] + 1;
                     flag[j] = "left_up";
                 } else {
                     if (temp[i - 1][j] >= temp[j - 1]) {
                         temp[j] = temp[i - 1][j];
                         flag[j] = "up";
                     } else {
                         temp[j] = temp[j - 1];
                         flag[j] = "left";
                     }
                 }
             }
         }
         return flag;
     }
     public static String getLongestSubsequence(String str1, String str2) {
         String[][] flagMatrix = getGenerationMatirx(str1, str2);
         String tempString = "";
         for (int i = str1.length(), j = str2.length(); i > 0 && j > 0;) {
                 if (flagMatrix[j].equals("left_up")) {
                     tempString += str1.charAt(i - 1);
                     i --;
                     j --;
                 } else if (flagMatrix[j].equals("left")) {
                     j --;
                 } else {
                     i --;
                 }
         }
         return new StringBuffer(tempString).reverse().toString();
     }

}
  运行结果:
DSC0002.png

  这里需要注意一点,因为LCS可能不止一个,所以对于flagMatrix的赋值其实不止一种情况,代码34行中大于或者大于等于都可以,但是可能会输出不同的结果。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-392293-1-1.html 上篇帖子: 2017-03-02华为项目添加检查点 下篇帖子: 中国华为:硅谷风混搭国企作派
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表