java基础程序题 判断一个字符串是否为回文 运用正则表达式处理字符串

来源:互联网 发布:美国电话号码格式 知乎 编辑:程序博客网 时间:2024/05/19 22:02
public class IsPalindrome {public static void main(String[] args) {String s = "A man, a plan, a canal: Panama";System.out.println(isPalindrome(s));} public static boolean isPalindrome(String s) { String reverse = ""; if(s == "") return true; //一般处理办法 //s = s.replaceAll(",", "").replaceAll(":", "").replaceAll(" ", ""); //正则表达式处理办法 s = s.replaceAll("[\\p{Punct}\\p{Space}]+", ""); System.out.println("用正则表达式去标点符号后的字符串: " + s); s = s.toLowerCase(); System.out.println("处理好的原始字符串: " + s);  for(int j = s.length()-1;j >= 0;j--) { reverse += s.charAt(j); //System.out.println("reverse = " + reverse); } System.out.println("倒序的字符串: " + reverse);  for(int i = 0;i<s.length();i++) { if(s.charAt(i) != reverse.charAt(i)) return false; }return true; }}
输出结果如下
用正则表达式去标点符号后的字符串: AmanaplanacanalPanama处理好的原始字符串: amanaplanacanalpanama倒序的字符串: amanaplanacanalpanamatrue


                                             
0 0