conditional adding of elements to an array

i have the following array: [2 2 4 6 7 16 20 29 48 81 130 163 235 308 414 496 535 521 509 465 355 275 198 120 72 31 16 8 4 2]
what i want to do is if the element of the array is greater than 50, then i replace the element by the the 50 then by the remainder so for example after converting the 10th element the array becomes [2 2 4 6 7 16 20 29 48 50 31 130 163 235 308 414 496 535 521 509 465 355 275 198 120 72 31 16 8 4 2]
how wcan this be done for any array ?

2 comentarios

James Tursa
James Tursa el 17 de Mzo. de 2018
Do this for only the first occurrence, or for all elements? What if the remainder is still greater than 50? Could an element expand into more than two elements?
Ahmad Beydoun
Ahmad Beydoun el 17 de Mzo. de 2018
yes the element should be divided till the floor of the division is zero and for all occurrence

Iniciar sesión para comentar.

 Respuesta aceptada

James Tursa
James Tursa el 17 de Mzo. de 2018
A = your data vector
n = whatever (e.g., 50)
result = cell2mat(arrayfun(@(x)[repmat(n,1,floor(x/n)),rem(x,n)],A,'uni',false));

2 comentarios

Ahmad Beydoun
Ahmad Beydoun el 17 de Mzo. de 2018
thank you !!! you have no idea how much i appreciate your help
James Tursa
James Tursa el 17 de Mzo. de 2018
You should use Rik's answer since he covers the case for exact multiples!

Iniciar sesión para comentar.

Más respuestas (1)

Rik
Rik el 17 de Mzo. de 2018
Not the most beautiful code I've ever written, but this should do what you want. I tested it as well with [0 50].
a=[2 2 4 6 7 16 20 29 48 81 130 163 235 308 414 496 535 521 509 465 355 275 198 120 72 31 16 8 4 2];
a=num2cell(a);
fun=@(x) [repmat(50,1,floor(x/50)) repmat(mod(x,50),1,mod(x,50)~=0)];
result=cellfun(fun,a,'UniformOutput',false);
result=cell2mat(result);

Categorías

Más información sobre Matrices and Arrays en Centro de ayuda y File Exchange.

Preguntada:

el 17 de Mzo. de 2018

Comentada:

el 17 de Mzo. de 2018

Community Treasure Hunt

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

Start Hunting!

Translated by