Update ReverseString.java
Using recursion for reversing a String serves us no benifit. It places extra load on the stack, and it is less efficient than doing so iteratively. I understand now that we can not use built in reverse function, but using recursion is still the worst way we could do the task of String reversal. Everytime we call the reverse method we are placing an extra frame on our stack. This uses space. We also create another string that we are appending our result to with the recursive solution, which is slow because under the hood, Java will create a new empty String and then append each character to the new String, one char at a time. If we do this for each character, then asymtotically we now have time complexity of O(n^2). Recursion in this case also does not make our solution "simpler" or "more elegant". We want to use recursion when it is advantageous to do so....like traversing trees
This commit is contained in:
parent
6ff4a1fb6f
commit
066dd615a6
@ -16,18 +16,16 @@ class ReverseString
|
|||||||
* @param str String to be reversed
|
* @param str String to be reversed
|
||||||
* @return Reversed string
|
* @return Reversed string
|
||||||
*/
|
*/
|
||||||
static String reverseString(String str)
|
public static String reverse(String str){
|
||||||
{
|
if(str.isEmpty() || str == null) return str;
|
||||||
String reverse="";
|
|
||||||
if(str.length()==1)
|
char arr[] = str.toCharArray();
|
||||||
{
|
for(int i = 0, j = str.length() - 1; i < j; i++, j--){
|
||||||
return str;
|
char temp = arr[i];
|
||||||
}
|
arr[i] = arr[j];
|
||||||
else
|
arr[j] = temp;
|
||||||
{
|
|
||||||
reverse=reverse+str.charAt(str.length()-1)+reverseString(str.substring(0,str.length()-1));
|
|
||||||
return reverse;
|
|
||||||
}
|
}
|
||||||
|
return new String(arr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user