Recursion revisited - can you help me?
Show older comments
function v = reversal(v)
if length(v) > 1
v = [v(end) reversal(v(1:end-1))];
end
end
5 Comments
Gerry Dumlao
on 28 Jun 2021
Walter Roberson
on 28 Jun 2021
Your second function is not recursive. Also it converts to double for no apparent reason.
Gerry Dumlao
on 28 Jun 2021
Gerry Dumlao
on 28 Jun 2021
Tests out okay
V = char(randi([33 126], 1, 31))
RV = reversal2(V)
isequal(RV, fliplr(V))
V = char(randi([33 126], 1, 32))
RV = reversal2(V)
isequal(RV, fliplr(V))
function v = reversal2(v)
if length(v) > 1
ii=round(length(v) /2 );
v = [reversal2(v(ii+1:end)) , reversal2(v(1:ii))];
end
end
Answers (2)
ghazal
on 2 Jul 2022
I have problem and this is my code, anyone can help me?
function v=reversal(v)
if length(v)==1
ii=round(length(v)/2);
v=[reversal(v(ii+1:end)) , reversal(v(1:ii))];
end
end
3 Comments
Walter Roberson
on 2 Jul 2022
What should happen if length(v) is not 1? Currently the code returns v unchanged in that case.
If length(v)==1 is true, then you execute the body of the if, and take length(v) which we know must be 1 (otherwise the condition would have been false.) round(1/2) is 1, so ii will always be 1 in that case (no point in computing it.) So you would call reversal(vv(2:end)) which would be reversal([]) which would end up returning the [] unchanged. And you would call reversal(v(1:1)) which would pass the same v into reversal (v must be scalar or the if would not be true), so you would end up calling reversal() with exactly the same input... which is going to call reversal([]) and reversal(v(1)) again which is going to call reversal([]) and reversal(v(1)) again and...
ghazal
on 3 Jul 2022
Thanks friend for your explanation actually I don't get where the problem is, but I changed my code to this and I get this Error!
Error:
Undefined function 'reversal' for input arguments of type 'double'.
Code:
function v = reversal2(v)
if length(v) > 1
ii=round(length(v) /2 );
v = [reversal2(v(ii+1:end)) , reversal2(v(1:ii))];
end
end
Walter Roberson
on 4 Mar 2024
You would have a problem running function reversal when the function is named reversal2
Jeevan
on 4 Mar 2024
0 votes
code run without output
1 Comment
Walter Roberson
on 4 Mar 2024
what code runs without output ?
Categories
Find more on Data Types in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!