
在实际的开发工作中,对字符串的处理是最常见的编程任务。本题目即是要求程序对用户输入的串进行处理。具体规则如下:
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个字符。
要求考生把所有类写在一个文件中。调试好后,存入与考生文件夹下对应题号的“解答.txt”中即可。相关的工程文件不要拷入。请不要使用package语句。
另外,源程序中只能出现JDK1.5中允许的语法或调用。不能使用1.6或更高版本。
import java.util.Scanner;
public class Test8 {
public String zhuanhua(String s) {
boolean start=false;
char[] b=s.toCharArray();
String s1="";
String s2="";
String s3="";
for(int i=0;i if(i>0&&b[i-1]==' '&&b[i]==' '){ start=false; } if(i>0&&b[i-1]!=' '&&b[i]==' '){ start=true; } if((b[i]==' '&&start)||b[i]!=' ') { s1+=b[i]; } } //System.out.println(s1); char[] c=s1.toCharArray(); if(c[0]>='a'&&c[0]<='z') { c[0]-='a'-'A'; } s2+=c[0]; for(int i=1;i c[i]-='a'-'A'; s2+=c[i]; continue; } s2+=c[i]; } //System.out.println(s2); char[] d=s2.toCharArray(); s3+=d[0]; for(int i=1;i boolean n=((d[i]>='a'&&d[i]<='z')||(d[i]>='A'&&d[i]<='Z'))&&(d[i-1]>='0'&&d[i-1]<='9'); if(m||n){ s3+="_"; } s3+=d[i]; } return s3; } public static void main(String[] args) { // TODO Auto-generated method stub Scanner sc=new Scanner(System.in); String s=sc.nextLine(); System.out.println(new Test8().zhuanhua(s)); } }
