package com.String;public class A {
public static void main(String[] args) {
String str = "this is a test of java";
t1(str);// static方法可直接调用
t2(str);
t3(str);
t4(str);
t5(str);
t6(str);
t8("123321");
} // 1.统计该字符串中字母s出现的次数
public static void t1(String str) { int num = 0;// 定义一个计数器
for (int i = 0; i < str.length(); i++) { char ch = str.charAt(i);// 获取当前位置的字符
if (ch == ‘s‘) {
num++;// 若有一个S,计数器+1
}
}
System.out.println("字符串中共有:" + num + "个s");
} // 2.取出子字符串"test"
public static void t2(String str) { int beginIndex = str.indexOf("test");// 子字符串的位置第一次出现的位置
int endIndex = beginIndex + 4;
String s = str.substring(beginIndex, endIndex);
System.out.println(s);
} // 3.用多种方式将本字符串复制到一个字符数组Char[]中
public static void t3(String str) { // 方法一:Char[] ch=str.toCharArray();
// 方法二:
char[] ch = new char[str.length()];// 定义一个数组
for (int i = 0; i < str.length(); i++) {
ch[i] = str.charAt(i);// 取出特定位置的字符交给数组
}
System.out.println(ch.length + "," + str.length());// 数组长度和字符串长度一致,则说明复制成功
} // 4.将字符串中每个单词的第一个字母变成大写, 输出到控制台。
public static void t4(String str) {
String[] ss = str.split(" ");// 以空格分出单词,得到字符串数组
String result = ""; for (int i = 0; i < str.length(); i++) { char c = ss[i].charAt(0);// 将单词的首字母取出
String s = String.valueOf(c);// 将字符转为字符串 或者a-97,A-65
String s1 = s.toUpperCase();// 变为大写
System.out.println(s1);
String s2 = s1 + ss[i].substring(1);// ss[i].substring(1):截取出每个单词中除了首字母之外剩下的字符串
result = result + s2 + " ";
}
System.out.println(result);
} // 5.实现该字符串的倒序输出
public static void t5(String str) {
String s = new StringBuffer(str).reverse().toString();// 匿名对象调用reverse方法逆转之后,变成字符串
System.out.println(s);
} // 6.将本字符串转换成一个字符串数组,要求每个数组元素都是一个有意义的英文单词,并输出到控制台
public static void t6(String str) {
String[] ss = str.split(" ");// 用空格分隔
for (int i = 0; i < str.length(); i++) { // 判断当前ss[i]是不是有效的单词:
boolean b = true;// 定义标志量b,默认b有效
for (int j = 0; j < str.length(); j++) { if (!((ss[i].charAt(j) >= ‘a‘ && ss[i].charAt(j) <= ‘z‘) || (ss[i]
.charAt(j) >= ‘A‘ && ss[i].charAt(j) <= ‘Z‘))) {
b = false;// ss[i]不是单词,只要有一个不是就跳出循环
break;
}
} if (b) {
System.out.println(ss[i]);
}
}
System.out.println("----------");
} // 8.判断输入字符串是否为回文(如 12344321、abccba是回文 112233不是)--对折后相同
public static void t8(String str) { //方法三:将字符串逆转,和原串相同,则为回文
//方法二:前一半和后一半字符串做计较
String s1 = str.substring(0, str.length() / 2);// 前一半字符串
String s2 = str.substring(str.length() / 2 + (str.length() % 2), str.length());// 后一半字符串
String s3 = new StringBuffer(s2).reverse().toString(); if (s1.equals(s3)) {
System.out.println("true");
}
}
} // 7.实现该字符串的按词倒叙输出。(即输出siht si a tset fo avaj).原文地址:http://11938725.blog.51cto.com/11928725/1834964