what's wrong with the code

for i=1:n
for j=1:n
if (5<i<15 & 8<j<12 & j=i) {d(i,j)=1};
else d(i,j)=0;
end
end
end

Answers (3)

Matt J
Matt J on 25 Mar 2013
Edited: Matt J on 25 Mar 2013
Of course, the whole thing could be done much more simply and without loops,
z=zeros(1,n);
z(min(9:11,n))=1;
d=diag(z);
n=40
for i=1:n
for j=1:n
if (5<i & i<15 & 8<j & j<12 & j==i) d(i,j)=1;
else d(i,j)=0;
end
end
end
Youssef  Khmou
Youssef Khmou on 25 Mar 2013
Edited: Youssef Khmou on 25 Mar 2013
modify,
for i=1:n
for j=1:n
if (5<i<15 && 8<j<12 && j==i)
d(i,j)=1;
else d(i,j)=0;
end
end
end

1 Comment

This has the same bug as the original. 5<i<15 means ((5<i)<15) which means "(true (1) or false (0)) < 15" which is always true.

This question is closed.

Tags

Asked:

on 25 Mar 2013

Closed:

on 20 Aug 2021

Community Treasure Hunt

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

Start Hunting!