# Problem with infinite loop in c program

Hi, I have a program that is entering a infinite loop in the last if else of this loop. The program is printing 3 endless times. Here is the code that generates it:
Code:
 else {
for (j=1;j<n;j++) {
if (j<=(n/2)) {
a[j] = j-1;
printf ("%d", a[j]);
}
else if (j=(n/2)+1) {
a[j] = a[j-1];
printf ("%d", a[j]);
//printf ("%d", j);
//break;
}
else if  {

a[j] = a[j-1]-1;
printf ("%d", a[j]);
break;
}
}
The three should be printed twice in a row, once by the if and the second time by the middle else if. Then the else should print decreasing values until the for loop end.
So, I don't understand why this is happening . J value it is 5 when it leaves the middle else if, which it is the correct value. Then it should not enter the last "else" in this iteration, since j needs to be bigger than (n/2)+1, which I expect to be (9/2)+1, which should be rounded to 5, so j should enter the last else only in the next iteration when it's value should be 6 and keep entering it for two more iterations, until it reaches the value of 9, which should end the for loop.

Here is the link for the full code in the case someone can compile it:

Thanks for any input.

Related Programming and Computer Science News on Phys.org
DavidSnider
Gold Member
What are you trying to do?

This code is very very difficult to read.

D H
Staff Emeritus
The code you entered is not the same as your code at codepad.org. The code you entered at this site isn't valid code. However, the bug is still present. Here it is:

else if (j=(n/2)+1) ...

You used a single '=' sign rather than two. With two you are comparing but with one you are assigning. You are assigning a value to j, and hence the infinite loop.

A good compiler will tell you about this common mistake if you let it do so. Enable all common warnings when compiling and then pay attention to those warnings.

• 1 person