程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java完成求兩個字符串最長公共子串的辦法

java完成求兩個字符串最長公共子串的辦法

編輯:關於JAVA

java完成求兩個字符串最長公共子串的辦法。本站提示廣大學習愛好者:(java完成求兩個字符串最長公共子串的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是java完成求兩個字符串最長公共子串的辦法正文


本文實例講述了java完成求兩個字符串最長公共子串的辦法。分享給年夜家供年夜家參考,詳細以下:

這個是華為OJ上的一道標題。起首,假如我們用java寫代碼,華為OJ有以下三條規矩需遵照,不然編譯沒法經由過程或許用例沒法經由過程,規矩以下:

(1)必定弗成以有包名;
(2)主類名只能為Main;
(3)弗成以輸入與成果有關的信息。

好了,依照以上規矩,我們寫出來的代碼以下(此代碼不是最優的,只是用來記載華為OJ上java代碼的書寫規矩):

import java.util.Scanner;
public class Main {
 public static void main(String[] args) {
  Scanner sc = new Scanner(System.in);
  Main mainObj = new Main();
  int len = mainObj.getCommonStrLength(sc.next(),sc.next());
  System.out.println(len);
 }
 int getCommonStrLength(String str1, String str2) {
   str1 = str1.toLowerCase(); 
   str2 = str2.toLowerCase(); 
   int len1 = str1.length(); 
   int len2 = str2.length(); 
   String min = null; 
   String max = null; 
   String target = null;
   min = len1 <= len2 ? str1 : str2;
   max = len1 > len2 ? str1 : str2;
   //最外層:min子串的長度,從最年夜長度開端
   for (int i = min.length(); i >= 1; i--) {
    //遍歷長度為i的min子串,從0開端
    for (int j = 0; j <= min.length() - i; j++) { 
     target = min.substring(j, j + i); 
     //遍歷長度為i的max子串,斷定能否與target子串雷同,從0開端
     for (int k = 0; k <= max.length() - i; k++) { 
      if (max.substring(k,k + i).equals(target)) { 
       return i; 
      }
     }
    }
   } 
   return 0; 
 }
}

願望本文所述對年夜家Java法式設計有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved