1. 分析:判断一个字符串是否是一个对称的字符串,我们只需要把字符串的第1个字符和最后1个字符,第2个字符和倒数第2个字符,……
比较的次数是长度除以2.
方法1:通过取取索引对应值来进行一一比对
方法2:通过StringBuffer的取反方法reverse获取其逆向值
2. 案例演示:
package cn.itcast_07; import java.util.Scanner; /*
* 判断一个字符串是否是对称字符串
* 例如"abc"不是对称字符串,"aba"、"abba"、"aaa"、"mnanm"是对称字符串
*
* 分析:
* 判断一个字符串是否是对称的字符串,我只需要把
* 第一个和最后一个比较
* 第二个和倒数第二个比较
* ...
* 比较的次数是长度除以2。
*/
public class StringBufferTest4 {
public static void main(String[] args) {
// 创建键盘录入对象
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个字符串:");
String s = sc.nextLine(); // 一个一个的比较
boolean b = isSame(s);
System.out.println("b:" + b); //用字符串缓冲区的反转功能
boolean b2 = isSame2(s);
System.out.println("b2:"+b2);
} public static boolean isSame2(String s) {
return new StringBuffer(s).reverse().toString().equals(s);
} // public static boolean isSame(String s) {
// // 把字符串转成字符数组
// char[] chs = s.toCharArray();
//
// for (int start = 0, end = chs.length - 1; start <= end; start++, end--) {
// if (chs[start] != chs[end]) {
// return false;
// }
// }
//
// return true;
// } public static boolean isSame(String s) {
boolean flag = true; // 把字符串转成字符数组
char[] chs = s.toCharArray(); for (int start = 0, end = chs.length - 1; start <= end; start++, end--) {
if (chs[start] != chs[end]) {
flag = false;
break;
}
} return flag;
}
}
程序的运行结果如下: