算法之LCS

  1. package com.eshore.sweetop.dynamicprogramming;
  2. public class LCS {
  3.     public static void LCSLength(char[] x, char[] y) {
  4.         int m = x.length;
  5.         int n = y.length;
  6.         int[][] c = new int[m + 1][n + 1];
  7.         char[][] b = new char[m + 1][n + 1];
  8.         for (int i = 1; i <= m; i++) {
  9.             c[i][0] = 0;
  10.         }
  11.         for (int i = 1; i < n; i++) {
  12.             c[0][i] = 0;
  13.         }
  14.         for (int i = 1; i <= m; i++) {
  15.             for (int j = 1; j <= n; j++) {
  16.                 if (x[i-1] == y[j-1]) {
  17.                     c[i][j] = c[i - 1][j - 1] + 1;
  18.                     b[i][j] = '※';
  19.                 } else if (c[i - 1][j] >= c[i][j - 1]) {
  20.                     c[i][j] = c[i - 1][j];
  21.                     b[i][j] = '↑';
  22.                 } else {
  23.                     c[i][j]=c[i][j-1];
  24.                     b[i][j]='←';
  25.                 }
  26.             }
  27.         }
  28.         display(b,x,m,n);   
  29.     }
  30.     
  31.     public static void display(char[][] b,char[] x,int i,int j){
  32.         if(i==0 || j==0){
  33.             return;
  34.         }
  35.         if(b[i][j]=='※'){
  36.             display(b,x,i-1,j-1);
  37.             System.out.print(x[i-1]);
  38.         }else if(b[i][j]=='↑'){
  39.             display(b,x,i-1,j);
  40.         }else{
  41.             display(b,x,i,j-1);
  42.         }
  43.     }
  44.     
  45.     public static void main(String[] args) {
  46.         char[] a={'A','B','C','B','D','A','B'};
  47.         char[] b={'B','D','C','A','B','A'};
  48.         LCS.LCSLength(a, b);
  49.         System.out.println();
  50.         LCS.LCSLength(b, a);
  51.     }
  52. }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值