题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
例如输入“I am a student.”,则输出“student. a am I”。
分析:由于编写字符串相关代码能够反映程序员的编程能力和编程习惯,与字符串相关的问题一直是程序员笔试、面试题的热门题目。本题也曾多次受到包括微软在内的大量公司的青睐。
参考地址:
http://zhedahht.blog.163.com/blog/static/254111742007289205219/
本文思路和原作者思路不同,本文的思路是,将字符串以空格分段,然后每段顺序压栈,压栈完毕后再出栈即可。
import java.util.LinkedList;
public class Test_07 {
/**
* @param args
*/
public static void main(String[] args) {
String str = "I am a student.";
reverseString(str);
}
public static void reverseString(String str){
LinkedList<String> list = new LinkedList<String>();
if(str == null)
{
return ;
}
String[] split = str.split(" ");
int len = split.length;
for(int i =0;i<len;i++){
list.add(split[i]);
}
while(list.size()!=0){
System.out.print(list.removeLast()+" ");
}
}
}
输出结果为:
student. a am I