leetcodesolution in java——Easy2
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcodesolution in java——Easy2相关的知识,希望对你有一定的参考价值。
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6410409.html
6:Reverse String
Write a function that takes a string as input and returns the string reversed.
此题:字符串反转题。
思路:此题大一学C++的时候上机题就做过了,当时思路是:把String转化为char[],从尾到头遍历一次倒序地把字符复制到另一个数组(从头到尾),然后把新数组toString()即可。现在用Java做的话,把新数组换成用StringBuffer代替,倒序遍历char[]逐个append到buffer,然后toString()即可。由于每个元素都遍历了一次,复杂度O(n)。
public String reverseString(String s) { char[] chars=s.toCharArray(); StringBuffer buffer=new StringBuffer(); for(int i=chars.length-1;i>=0;--i){ buffer.append(chars[i]); } return buffer.toString(); }
第二种思路是:把char[]的前后半交换即可,只需遍历一半,复杂度O(n/2)。
public String reverseString(String s) { char[] chars=s.toCharArray(); int half=chars.length/2; for(int i=0;i<half;++i){ char temp=chars[chars.length-1-i]; chars[chars.length-1-i]=chars[i]; chars[i]=temp; } //这里注意:char[]转化为String是通过new String(char[])实现的 return new String(chars); }
以上是关于leetcodesolution in java——Easy2的主要内容,如果未能解决你的问题,请参考以下文章
JPQL IN 子句:Java 数组(或列表、集合...)?
java 小程序误区。。FileInputStream in = null; try in = new FileInputStream(。。。。。为啥这么定