function mx=recursive_max(v)
if numel(v)==1
mx=v;
end
if numel(v)>1
mx= recursive_max(1);
end
this much i've got so far.
Please help with this code.

1 Kommentar

When we use this,it shows error as
incorrectRandom vector Variable mx has an incorrect value. Test failed using v =[ 14 92 89 27 8 ]

Melden Sie sich an, um zu kommentieren.

 Akzeptierte Antwort

Stephen23
Stephen23 am 10 Sep. 2020
Bearbeitet: Stephen23 am 10 Sep. 2020

5 Stimmen

Urmish Haribhakti's general approach is quite good, with a few small changes it will work correctly:
function x = recmax(v)
if numel(v)<=1
x = v;
else
x = recmax(v(2:end));
if v(1)>x
x = v(1);
end
end
end
And tested:
>> recmax([28,2,6,1,999,8])
ans = 999

2 Kommentare

Thank you so much!
can anyone please explain this code

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (5)

Mati Somp
Mati Somp am 9 Okt. 2020

3 Stimmen

One more
function mx = recursive_max(v)
if length(v)==1
mx=v
else
if v(1)<=v(2)
v(1)=[]
else
v(2)=[]
end
mx=recursive_max(v)
end

1 Kommentar

xin yi leow
xin yi leow am 25 Jan. 2021
This works for me and is easy to understand! if v(1) < v(2), we remove the first element, and if v(2)<v(1), we remove the v(2), that way we only keep the larger of the 2 elements in the vector. The last remaining element will naturally be the largest one.

Melden Sie sich an, um zu kommentieren.

Ameer Hamza
Ameer Hamza am 9 Sep. 2020
Bearbeitet: Ameer Hamza am 10 Sep. 2020

2 Stimmen

Something like this:
function mx = recursive_max(v)
x = zeros(1, 2);
if numel(v) > 2
a = floor(numel(v)/2);
x(1) = recursive_max(v(1:a));
x(2) = recursive_max(v(a+1:end));
elseif numel(v) == 1
x = [v -inf];
else
x = v;
end
if x(1) > x(2)
mx = x(1);
else
mx = x(2);
end
end
I am not sure if this is an optimal algorithm.

2 Kommentare

Piyush Gupta
Piyush Gupta am 10 Sep. 2020
Bearbeitet: Piyush Gupta am 10 Sep. 2020
can you explain the code....
Ameer Hamza
Ameer Hamza am 10 Sep. 2020
It divides the input vector into two parts recursively. When the length of the divided vector reaches two during recursion, the recursion stops, and the function returns back the largest of the two elements.

Melden Sie sich an, um zu kommentieren.

JAYANTHI SANKARALINGAM
JAYANTHI SANKARALINGAM am 20 Sep. 2020

0 Stimmen

Write a function called recursive_max that finds the maximum element in a vector without using loop or any built in functions.the sole output argument is the maximum value in the input vector.
Himalsha Dharmapala
Himalsha Dharmapala am 15 Jan. 2021

0 Stimmen

function output= recursive_max3(v)
if v(1,:)==0
output=v(1);
else
if v(end)>=v
output=v(end);
else
output= recursive_max3(v(1:end-1));
end
end
end
Welid Benchouche
Welid Benchouche am 18 Aug. 2021

0 Stimmen

my solution to this assignment is
function mx = my_recursive_max(v)
% base case
if length(v) == 1
mx = v;
else
% recursive case
a = v(end);
b = v(1);
if a <= b
mx = b;
mx = my_recursive_max(v(1:end-1))
else
mx = a;
mx = my_recursive_max(v(2:end))
end
end

Kategorien

Mehr zu Loops and Conditional Statements finden Sie in Hilfe-Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by