字符串反转-java
2009-11-13 15:22
441 查看
/*
*将一个字符串反转:Hello world --> world Hello
*
*/
//对一个char数组进行整体反转
public static void subReverse(char[] str, Integer begin, Integer end) {
char temp;
while (begin <= end) {
temp = str[begin];
str[begin] = str[end];
str[end] = temp;
begin++;
end--;
}
}
public static void reverse(String str) {
// String str = "Hello World Welcome to china";
//构造每个分割的下标
List index = new ArrayList<Integer>();
char[] str1 = str.toCharArray();
index.add(-1);
for (int k = 0; k < str1.length; k++) {
if (str1[k] == ' ')
index.add(k);
}
index.add(str1.length);
//首先每个单词反转
for (int k = 0; k < index.size() - 1; k++) {
subReverse(str1, (Integer) index.get(k) + 1, (Integer) index
.get(k + 1) - 1);
}
//再对整体进行反转
subReverse(str1, 0, str1.length - 1);
for (int i = 0; i < str1.length; i++) {
System.out.print(str1[i]);
}
}
*将一个字符串反转:Hello world --> world Hello
*
*/
//对一个char数组进行整体反转
public static void subReverse(char[] str, Integer begin, Integer end) {
char temp;
while (begin <= end) {
temp = str[begin];
str[begin] = str[end];
str[end] = temp;
begin++;
end--;
}
}
public static void reverse(String str) {
// String str = "Hello World Welcome to china";
//构造每个分割的下标
List index = new ArrayList<Integer>();
char[] str1 = str.toCharArray();
index.add(-1);
for (int k = 0; k < str1.length; k++) {
if (str1[k] == ' ')
index.add(k);
}
index.add(str1.length);
//首先每个单词反转
for (int k = 0; k < index.size() - 1; k++) {
subReverse(str1, (Integer) index.get(k) + 1, (Integer) index
.get(k + 1) - 1);
}
//再对整体进行反转
subReverse(str1, 0, str1.length - 1);
for (int i = 0; i < str1.length; i++) {
System.out.print(str1[i]);
}
}
相关文章推荐
- JAVA字符串的反转和比较
- Java 中把一个字符串反转
- 由字符串反转(使用递归)引申出来一道Java面试题
- java反转字符串,不改变标点符号位置,多空格显示为一个的最优写法
- java中两个字符交换内容(可用于字符串反转)
- Java字符串反转
- Java 字符串反转实现代码
- 字符串反转 -- java实现
- java中字符串的反转
- Java 字符串反转实现
- c++,java,python 的字符串反转方法(回文数比较)
- java字符串基础小知识,字符串去除空格,排序,反转
- Java实现字符串反转
- 7 种将字符串反转的 Java 方法
- java 字符串反转
- java基础——字符串中的反转Reverse问题(面试必备)
- Java中字符串反转
- Java 字符串反转
- java如何实现字符串的反转及替换
- Java反转字符串