zoukankan      html  css  js  c++  java
  • Java去除字符串多余空格以及首尾空格

    对于这个问题,我的处理方法是:

    1.先通过递归数出字符串中连续空格的个数。

    2.将有连续空格的位置去除多余空格。

    3.判断首尾是否有空格。

    第一步,判断当前位置是否是空格以及连续空格的个数,这里使用一个递归的方法比较简单。代码如下:

    public static int getBlankNumber(String s, int index)
    {
        if (index < s.length()) {
            if (s.charAt(index) == ' ') {
                return getBlankNumber(s, index + 1) + 1;
            } else {
                return 0;
            }
        } else {
            return 0;
        }
    }

    传入字符串对象 s ,以及当前的位置 index,最终返回一个 int 型的结果,也就是多少个空格。

    第二步,跟上返回的空格数,与当前的位置,使用 String 对象自带的 substring() 方法,将字符串分割为两部分,去掉中间的空格,再连接起来,使连续多个空格变为一个。代码如下:

    public static String mergeBlank(String s)
    {
        int numberBlank = 0;
        String a1;  //字符串的第一部分
        String a2;  //字符串的第二部分
        for (int index = 0; index < s.length(); index++) {  //循环整个字符串,判断是否有连续空格
            numberBlank = getBlankNumber(s, index);
            if (numberBlank >= 2) {  //根据连续空格的个数以及当前的位置,截取字符串
                a1 = s.substring(0, index);
                a2 = s.substring(index + numberBlank - 1, s.length());
                s = a1 + a2;  //合并字符串
            }
        }
        return s;
    }

    第三步,第二步完成之后,第三步就很简单了,因为我们已经将字符串中多余的空格变为一个空格,如果需要去除首尾空格,只需要判断首尾是否是空格即可。代码如下:

    public static String trim(String s)
    {
        if (s.charAt(0) == ' ') {
            s = s.substring(1, s.length());
        }
        if (s.charAt(s.length() - 1) == ' ') {
            s = s.substring(0, s.length() - 1);
        }
        return s;
    }

    这样一来,一个去除多余空格,去除首尾空格的函数就完成了。接下来调用一下看看,代码如下:

    public static void main(String[] args) {
        String name = mergeBlank("   aaa   a     aa       ");
        System.out.println("name="+name+"|");  //结果:name= aaa a aa |
        name = trim(name);
        System.out.println("name="+name+"|");  //结果:name=aaa a aa|
    }
  • 相关阅读:
    treap模板
    Codeforces Round #446 (Div. 2)
    BZOJ 1001: [BeiJing2006]狼抓兔子 (最小割)
    NOIP2017总结
    Python 操作 Mysql 模块
    poj 3660 Cow Contest (传递闭包)
    poj 1964 Cow Cycling(dp)
    poj 3671 Dining Cows (Dp)
    cogs 线型网络(状压dp)
    codevs 2800 送外卖(状压dp)
  • 原文地址:https://www.cnblogs.com/kross/p/2973507.html
Copyright © 2011-2022 走看看