0

I can't understand this code.Could anyone explain to me?

public class Main { static String rev(String str){ return str.length()<2?str:rev(str.substring(1))+str.charAt(0); } public static void main(String[] args) { String string="edon"; System.out.println(rev(string)); } }

20th May 2022, 1:31 PM
Killiam Chances
Killiam Chances - avatar
2 Answers
+ 2
Suppose rev actually correctly reverses a string. Then a string "edon" is returned as the reverse of "don", which is the substring from index 1, and reverses to "nod" and concatenate with the first char, which is 'e'. So, it returns "node". So far we have seen that if a string of length n reverses correctly, so does a string of length (n+1). And for a string of length 1, or < 2, it returns the string, which certainly is itself reversed. So, it is reversing strings of length 1, thus also strings of length 2. Thus strings of length 3, thus of length 4, and so on. In short, it reverses a string of any finite length. A classic example of a recursive algorithm that solves a problem through a solution of the same problem but of smaller size.
20th May 2022, 1:47 PM
Ani Jona 🕊
Ani Jona 🕊 - avatar
+ 1
rev("n") rev("on") rev("don") This is how your stack call would look like. "n" -> returned from top "no" -> here onwards charAt(0) will come "don" "node" After the end of call stack you would get your string in reverse order.
20th May 2022, 1:57 PM
Avinesh
Avinesh - avatar