统计回文--一道面试题的反思

这倒特别简单的题被我做成什么个样子,我也是醉了。

题目描述 “回文串”是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。花花非常喜欢这种拥有对称美的回文串,生日的时候她得到两个礼物分别是字符串A和字符串B。现在她非常好奇有没有办法将字符串B插入字符串A使产生的字符串是一个回文串。你接受花花的请求,帮助她寻找有多少种插入办法可以使新串是一个回文串。如果字符串B插入的位置不同就考虑为不一样的办法。

例如: A = “aba”,B = “b”。这里有4种把B插入A的办法:
* 在A的第一个字母之前: “baba” 不是回文
* 在第一个字母‘a’之后: “abba” 是回文
* 在字母‘b’之后: “abba” 是回文
* 在第二个字母’a’之后 “abab” 不是回文
所以满足条件的答案为2
输入描述:

每组输入数据共两行。 第一行为字符串A 第二行为字符串B 字符串长度均小于100且只包含小写字母
输出描述:

输出一个数字,表示把字符串B插入字符串A之后构成一个回文串的方法数
输入
aba
b
输出
2

这道题特别好做,就是用到StringBuffer类中的,插入,翻转,连接,也就是insert(),reverse(),append()方法就可以完成了,可是我忘记了,所以我用的是String类中的getChar()方法,其实这个方法是复制,而不是插入。
例如
String str = “abcdefghikl”;
Char[] ch = new char[8];
str.getChars(2,5,ch,0);
就是从str的第二个字母开始一直复制到第五个,一共是3个字符,从ch的第一个开始接受.


正确的做法:

import java.io.BufferedReader;
import java.io.InputStreamReader;

public class ee{
    public static void main(String[] args) throws Exception {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String a = br.readLine();
        String b = br.readLine();
        int count = 0;
        StringBuffer s = new StringBuffer(a);
        for(int i=0;i<s.length();i++){
            StringBuffer temp = new StringBuffer(s);
            temp.insert(i,b);
            if(isF(temp)){
                count ++;
            }
        }
        if(isF(s.append(b))){
            count ++;
        }
        System.out.println(count);
    }
    /*以下方法对原字符串和翻转后的字符串比较:
    为什么不用equals()方法直接比较?
    StringBuffer类里面没有equals方法,需要重写,所以该方法就相当于重写的equals方法。
    */
    public static boolean isF(StringBuffer sb){
        StringBuffer temp = new StringBuffer(sb);
        StringBuffer re = temp.reverse();//将temp的值赋给re
        for(int i=0;i<sb.length();i++){
            if(sb.charAt(i) != re.charAt(i)){
                return false;
            }
        }
        return true;
    }
}

在该题目中遇到的问题:
1.String类中的getChars()方法不是插入,而是复制。
2.StringBuffer类中的reverse()方法,翻转后的字符串又赋值给本身。
3.Stringbuffer类中没有重写equals方法,不能直接调用。

第二种方法

import java.util.*;
public class ff{
    public static void main(String args[]){
        Scanner sc = new Scanner(System.in);
        while(sc.hasNext()){
            String a = sc.nextLine();
            String b = sc.nextLine();
            int m = 0;
            for(int i=0;i<a.length()+1;i++){
                String str = a.substring(0,i)+b+a.substring(i,a.length());
                StringBuffer sb = new StringBuffer(str);

                if(sb.reverse().toString().equals(str)){
                    m++;
                }
            }
            System.out.print(m);
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值