算法练习-串的简单处理

在实际的开发工作中,对字符串的处理是最常见的编程任务。
本题目即是要求程序对用户输入的串进行处理。具体规则如下:
1. 把每个单词的首字母变为大写。
2.把数字与字母之间用下划线字符(_)分开,使得更清晰
3. 把单词中间有多个空格的调整为1个空格。

这道题很简单,用不到太难的算法,主要就是考你的细心程序,要考虑到所有的情况
首先说一个常规的解法
1)遍历所有情况:

public class 串的简单处理 {

    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        String string=sc.nextLine();
        Vector<Character> vector=new Vector<Character>();
        for(int i =0;i<string.length();i++){
            vector.add(string.charAt(i));
        }
        int index=0;
        while(index<vector.size()){
            if(index==0&&vector.elementAt(index)>='a'&&vector.elementAt(index)<='z'){
                vector.set(index, (char)(vector.elementAt(index)-('a'-'A')));
            }else if(vector.elementAt(index-1)==' '&&vector.elementAt(index)==' '){
                vector.remove(index);
                index--;
            }else if(vector.elementAt(index-1)==' '&&vector.elementAt(index)>='a'&&vector.elementAt(index)<='z'){
                vector.set(index, (char)(vector.elementAt(index)-('a'-'A')));
            }else if(vector.elementAt(index)>='a'&&vector.elementAt(index)<='z'&&
                    vector.elementAt(index-1)>='0'&&vector.elementAt(index)<='9'){
                vector.add(index,'_');
                index++;
            }
            index++;
        }
        for(int i=0;i<vector.size();i++){
            System.out.print(vector.elementAt(i));
        }
        System.out.println();
    }

}

重点是这个正则表达式的解法

public class 串的简单那处理2 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        String str="";
        str=(new Scanner(System.in)).nextLine();
        String[] str1=str.split("[ ]+");//以空格分组
        for(int i=0;i<str1.length;i++){
            str1[i]=String.valueOf((char)(str1[i].charAt(0)+('A'-'a')))+str1[i].substring(1);
        }
        String s="";
        for(int i=0;i<str1.length-1;i++){
            s+=str1[i]+" ";
        }
        s+=str1[str1.length-1];
        Pattern p=Pattern.compile("([0-9]+)");//正则表达式实例化
        Matcher m=p.matcher(s);//以正则表达式创建匹配器
        String fin="";
        int st=0;
        while(m.find()){
            int start=m.start();
            int end=m.end();
            fin+=s.substring(st, start);//将数字之前的字符串写入fin中
            if(s.charAt(start-1)!=' ')
                fin+="_";
            fin+=m.group(1);//fin中加入匹配的字符串
            if(s.charAt(end)!=' ')
                fin+="_";
            st=end;
        }
        if(st<s.length())
            fin+=s.substring(st);//fin中加入剩下的去除数字的字符串
        System.out.println(fin);

    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值