Java算法--串的简单处理

题目如下:

串的处理

在实际的开发工作中,对字符串的处理是最常见的编程任务。

本题目即是要求程序对用户输入的串进行处理。具体规则如下:

1. 把每个单词的首字母变为大写。

2. 把数字与字母之间用下划线字符(_)分开,使得更清晰

3. 把单词中间有多个空格的调整为1个空格。

例如:

用户输入:

you and me what cpp2005program

则程序输出:

You And Me What Cpp_2005_program

用户输入:

this is a 99cat

则程序输出:

This Is A 99_cat

我们假设:用户输入的串中只有小写字母,空格和数字,不含其它的字母或符号。

每个单词间由1个或多个空格分隔。

假设用户输入的串长度不超过200个字符。

方法一:

public class 串的简单处理 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String string = scanner.nextLine();
        Vector<Character> vector = new Vector<Character>();
        for (int i = 0; i < string.length(); i++) {
            vector.add(string.charAt(i));
        }
        try {
            int index = 0;
            while (index < vector.size()) {
                //判断第一个是否为小写的英文字符,是的话进行操作
                if (index == 0 && vector.elementAt(index) >= ‘a‘
                        && vector.elementAt(index) <= ‘z‘) {
                    //Replaces the element at the specified position in this Vector with the specified element
                    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 - 1) <= ‘9‘)) {
                    vector.add(index, ‘_‘);
                    index++;
                } else if ((vector.elementAt(index - 1) >= ‘a‘ && vector
                        .elementAt(index - 1) <= ‘z‘)
                        && (vector.elementAt(index) >= ‘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();
        } catch (ArrayIndexOutOfBoundsException e) {
        }
    }
}

方法二:主要用到正则表达式对字符串进行截取,然后对每一个字符数组的元素进行正则匹配,含有数字的单独进行处理

public class SimpleString {

    // 打印字符串的函数
    public static void print(String[] s) {
        for (int i = 0; i < s.length - 1; i++) {
            System.out.print(s[i] + " ");
        }
        System.out.println(s[s.length - 1]);
    }

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String s = scan.nextLine();
        String[] ss = s.split("[\\s]+"); // 根据正则表达式,删除一个或多个空格,将字符串保存为字符数组
        for (int i = 0; i < ss.length; i++) {
            // 将每一个字符数组的首字母改为大写
            String up = ("" + ss[i].charAt(0)).toUpperCase(); // 大写
            StringBuffer sb = new StringBuffer(ss[i]);
            ss[i] = sb.replace(0, 1, up).toString();

            // 上边已经把字符串数组的首字母该为大写,然后对更改后的字符数组判断是否有数字
            Matcher m = Pattern.compile("\\d+").matcher(ss[i]);// 0-9出现一次或多次
            while (m.find()) {
                // m.group():Returns the input subsequence matched by the previous match
                String num = new String(m.group());
                String num2 = num;
                num2 = "_" + num + "_"; // 数字前后都添加"_"
                ss[i] = ss[i].replace(num, num2);
                if (ss[i].startsWith("_")) { // 去头"_"
                    ss[i] = ss[i].substring(1);
                }
                if (ss[i].endsWith("_")) { // 去尾"_"
                    ss[i] = ss[i].substring(0, ss[i].length() - 1);
                }
            }
        }
        print(ss);
    }
}

时间: 2024-11-07 15:26:57

Java算法--串的简单处理的相关文章

java 算法基础

1.算法概要 算法是用于计算.数据处理和自动推理使用的.算法主要是做精确计算和表示一个有限长列的有效方法.算法一般包含清晰定义的指令用于计算函数.基本上也属于一种思考最简洁的方式. 2.算法特征 算法主要包含五个特征 2.1.有穷性: 是指算法必须能在执行有限个步骤后终止: 2.2.确切性: 算法的每一个步骤必须有确切的定义: 2.3.输入项: 一个算法输入有0或多个输入,以刻画预算对象的初始情况,所谓0就是初始化条件: 2.4.输出项: 反馈对数据加工后的结果.没有输出的算法无意义. 2.5.

12道Java算法与编程面试题

12道Java算法与编程面试题自己整理的面试题,希望可以帮到大家,需要更多资料的可以私信我哦,大家一起学习进步! 算法与编程1.编写一个程序,将a.txt文件中的单词与b.txt文件中的单词交替合并到c.txt文件中,a.txt文件中的单词用回车符分隔,b.txt文件中用回车或空格进行分隔.答:package cn.itcast; import java.io.File;import java.io.FileReader;import java.io.FileWriter; public cla

java实现串的匹配和替换

/** *测试类,测试两个功能类,MatchBrote_force类和subString_act类的功能实现*创建的类为TestMatchBrote_force *@author LZ *@vesion 6.2 */ //import com.edu.software.LZ.*; public class TestMatchBrote_force { public static void main(String[] args){ /** *新建对象调用MatchBrote_force类*得到字串

JAVA算法基础-贪心算法

前言 学无止境.算法博大精深啊,一个贪心算法里面就隐含了这么多不同的场景实现,每个场景下的算法就有多种不同的实现,个人写法不一也成就了各种不同的漂亮算法,看了这些实现,也让我开拓了思维,这个世界的方案永远没有最完美的只有最合适的- ! 1.贪心算法概念 贪心算法也叫贪婪算法,当然叫法随意.主要目的是在问题求解时,做出最正确的判断= =,这不是贪心是啥?在计算机工程领域当中,就是说不考虑整体最优算法而是从局部做到最优解.当然贪心是算法不能对所有的问题都能得到整体都最优解,但对多数个问题还是能得到近

Java算法与数据结构

Java算法与数据结构学习 一.数组 //声明数组 dataType[] arrayRefVar; //创建数组 arrayRefVar = new dataType[arraySize]; dataType[] arrayRefVar = new dataType[arraySize]; dataType[] arrayRefVar = {value0, value1, ..., valuek}; 1.使用自定义类封装数组 public class MyArray{ private long

算法学习#09--用简单的思维理解选择、插入、冒泡和希尔排序

选择排序 1.原理 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾.以此类推,直到所有元素均排序完毕. 2.特点 ①运行时间与输入无关. 无论输入初始状态如何,是否有序,都需要遍历数组来找出最小的元素.其他算法则更善于利用输入的初始状态来优化时间. ②数据移动次数最小. 如果某个元素位于正确的最终位置上,则它不会被移动.选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进

java中,一个简单但出错率又大的‘加法’题,1+1+&#39;1&#39;+1+1+1+1+&quot;1&quot;=?

1+1+'1'+1+1+1+1+"1"=? 结果是多少?很多人看了题之后,可能会说结果是71.  当然有的童鞋可能会说很简单,放工具里运行一下就知道结果了,如果不运行代码,你会得出一个什么样的结果呢? 如果告诉你答案是551,会迷惑么?怎么会得出551? 下面我们来看看怎么算的: 1.我们大家都知道1 .'1'."1"的区别,1 表示一个int类型,’1'是表示一个char类型,"1" 表示一个字符串类型. 2.1+1+'1'+1+1+1+1+&

java 自定义异常,记录日志简单说明!留着以后真接复制

log4j 相关配制说明:http://blog.csdn.net/liangrui1988/article/details/17435139 自定义异常 package org.rui.ExceptionTest; public class ExtraFeature { //-------使用------ public static void f()throws MyException { System.out.println("MyException from f()"); thr

多线程(三) java中线程的简单使用

============================================= 原文链接:多线程(三) java中线程的简单使用 转载请注明出处! ============================================= java中,启动线程通常是通过Thread或其子类通过调用start()方法启动. 常见使用线程有两种:实现Runnable接口和继承Thread.而继承Thread亦或使用TimerTask其底层依旧是实现了Runnabel接口.考虑到java的