串的处理
在实际的开发工作中,对字符串的处理是最常见的编程任务。
本题目即是要求程序对用户输入的串进行处理。具体规则如下:
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个字符。
法一:逐个char存入vector 循环判断
import java.util.Scanner;
import java.util.Vector;
public class Main {
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-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();
}
}
法二:正则表达式,匹配 1:空格 2:数字 String数组处理char
public class Main {
public static void main(String[] args) {
String str=(new Scanner(System.in)).nextLine();
String[] str1=str.split("[ ]+");//正则表达式匹配 [ ]内部可选 +:>=1个
String s="";
for(int i=0;i<str1.length;i++)
if('a'<=str1[i].charAt(0) && str1[i].charAt(0)<='z')
str1[i]=String.valueOf((char)(str1[i].charAt(0)-('a'-'A')))+str1[i].substring(1);
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);
int st=0;
String fin="";
while(m.find()){
int start=m.start();
int end=m.end();
fin+=s.substring(st,start);
if(start>1 && s.charAt(start-1)!=' ')
fin+="_";
fin+=m.group(1);
if(end<s.length() && s.charAt(end+1)!=' ')
fin+="_";
st=end;
}
if(st<s.length())
fin+=s.substring(st);
System.out.println(fin);
}
//you and me what 2005program
}
法三:String split 再 逐个匹配处理
public class Main {
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) {
String s=(new Scanner(System.in)).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)+"";
Matcher m=Pattern.compile("\\d+").matcher(ss[i]);
while(m.find()){
String num=new String(m.group());
String 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);
}
//you and me what 2005program
}