multiple loop and produce infinite loop

1 visualización (últimos 30 días)
Khairul Nur
Khairul Nur el 25 de Oct. de 2019
Comentada: Khairul Nur el 25 de Oct. de 2019
hi, i have trouble using while loop. Where should i put the j inrement? i try fews times but infinite loop. Thanks in advance.
k = 4
j = 1
i=1
while j <= k
for n = i:40
if (G(i,11)) == j
mean = sum(G(i:10))/length(G)
i=i+1
break
end
%j=j+1
end
%j=j+1
end
  1 comentario
Guillaume
Guillaume el 25 de Oct. de 2019
Editada: Guillaume el 25 de Oct. de 2019
What is the code meant to be doing?
Note that using length on a 2D matrix is asking for a lot of trouble. Is that length supposed to return the number of rows or the number of columns (note that it can return either depending on the actual size of G)
And naming a variable mean is also a very bad idea since it prevents you from using the mean function.
Is the switching from 2D indexing (in G(i, 11)) to linear indexing (in G(i:10)) on purpose or a major error?

Iniciar sesión para comentar.

Respuestas (1)

adeq123
adeq123 el 25 de Oct. de 2019
This one works for me:
G = 100:1:1000;
k = 4;
j = 1;
i = 1
while j <= k
for n = i:40
if G(i,11) == j
mean = sum(G(i:10))/length(G)
i = i+1
break
end
%j=j+1
end
j=j+1
end
  3 comentarios
adeq123
adeq123 el 25 de Oct. de 2019
The j is incremaneting at the end of while loop. During the last iteration it is increament to 5 but the loop is not executed since entrance criteria is not met.
You can also do this one:
G = 100:1:1000;
k = 4;
j = 0;
i = 1
while j < k
j=j+1
for n = i:40
if G(i,11) == j
mean = sum(G(i:10))/length(G)
i = i+1
break
end
%j=j+1
end
end
But the result is the same as previous.
Khairul Nur
Khairul Nur el 25 de Oct. de 2019
thanks for the explainantion, if i want to make j=2 is execute within for loop for the 2nd iteration..where should i put the j=j+1

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by