如何判断一个字符串是前后对称的?
什么意思呢?就好像一个字符串,前后一折,是对称的。就像你站在镜子前,看到了一个玉树临风、闭月羞花的自己。
public class PalindromeString { public static void main(String[] args) { checkPalindromeString("沉默王二"); checkPalindromeString("沉默王二 二王默沉"); } private static void checkPalindromeString(String input) { boolean result = true; int length = input.length(); for (int i = 0; i < length / 2; i++) { if (input.charAt(i) != input.charAt(length - i - 1)) { result = false; break; } } System.out.println(input + " 对称吗? " + result); } }
输出结果如下所示:
沉默王二 对称吗? false 沉默王二 二王默沉 对称吗? true
说一下我的思路:要判断字符串对折后是否对称,很简单,从中间劈开,第一个字符对照最后一个字符,一旦找到不等的那个,就返回 false。
注意三点:
1)for 循环的下标从 0 开始,到 length/2 结束。
2)下标 i 和 length-i-1 是对称的。
3)一旦 false 就 break。
以上是如何判断一个字符串是否对称。的详细内容。更多信息请关注PHP中文网其他相关文章!