字符串逆序,这个问题有很多衍生问题,他的实现方式也有很多。今天收藏的是,代码行数最好的实现方式。
那就是使用递归的方式,用1行代码实现字符串逆序。
代码如下:
public class reverseStringDemo {
public static void main(String args[]) {
System.out.println("结果:"+reverseString("Hollis is a Coder"));
}
private static String reverseString(String sentense) {
System.out.println(sentense.isEmpty() ? sentense : sentense + " || " + sentense.charAt(0));
String result = sentense.isEmpty() ? sentense:reverseString(sentense.substring(1)) + sentense.charAt(0);
System.out.println(sentense.isEmpty()?"":result + " || " + sentense.charAt(0));
return result;
}
}
输出结果:
Hollis is a Coder || H
ollis is a Coder || o
llis is a Coder || l
lis is a Coder || l
is is a Coder || i
s is a Coder || s
is a Coder ||
is a Coder || i
s a Coder || s
a Coder ||
a Coder || a
Coder ||
Coder || C
oder || o
der || d
er || e
r || r
r || r
re || e
red || d
redo || o
redoC || C
redoC ||
redoC a || a
redoC a ||
redoC a s || s
redoC a si || i
redoC a si ||
redoC a si s || s
redoC a si si || i
redoC a si sil || l
redoC a si sill || l
redoC a si sillo || o
redoC a si silloH || H
结果:redoC a si silloH
如上,核心代码只有一行,那就是:
sentense.isEmpty() ? sentense : reverseString(sentense.substring(1)) + sentense.charAt(0);
这行代码中主要有两个知识点,分别使用了三目运算符和递归。
三目运算符
对于条件表达式b ? x : y,先计算条件b,然后进行判断。如果b的值为true,计算x的值,运算结果为x的值;否则,计算y的值,运算结果为y的值。
递归
程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法在程序设计语言中广泛应用。一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。
按照我自己的理解就是整块代码三目运算是比较好理解的,递归方法呢,就是在字符串还没有截取成空串之前一直在调用递归方法reverseString,当字符串最终被截取成为""时,也就是递归方法调用结束了,接下来就是一层一层返回之前调用方法的值,最终返回一个倒叙的字符串。根据控制台的输出语句也比较容易理解整个方法调用逻辑。
当然也有函数直接可以实现,例如:
StringUtils.reverse("Hollis is a Coder")
我们点进入方法内部,也可以看到他的底层实现方法原理类似于上述逻辑。
只不过最底层的处理数据用了别的方法: