思路:回文串的特點是,逆序輸出和正序輸出是一樣的。所以這道題可以從這方面來考慮。如果將此字符串逆序輸出,那么兩個字符串的最長公共子序列將是最長的回文字符串,那么剩余的值將是要刪除的字符個數。
求LCS的方法可以在csdn中找到。
import java.util.*; public class Main{ public static void main(String[] args){ Scanner scan = new Scanner(System.in); while(scan.hasNext()){ String str = scan.nextLine(); System.out.println(str.length()-getResult(str)); } } public static int getResult(String str){ StringBuilder sb = new StringBuilder(str); String newStr = sb.reverse().toString(); char[] c1 = str.toCharArray(); char[] c2 = newStr.toCharArray(); int n = str.length(); int[][] dp = new int[n+1][n+1]; for(int i=1;i<n+1;i++){ for(int j=1;j<n+1;j++){ if(c1[i-1]==c2[j-1]){ //此處應該減1. dp[i][j]=dp[i-1][j-1]+1; }else{ dp[i][j]=Math.max(dp[i-1][j],dp[i][j-1]); } } } return dp[n][n]; } }