yego.me
💡 Stop wasting time. Read Youtube instead of watch. Download Chrome Extension

while loops | Intro to CS - Python | Khan Academy


4m read
·Nov 10, 2024

What if you want your program to repeat a block of code? You could copy and paste those lines of code. But what if you wanted to repeat it 100 times or a thousand times? Or maybe you don't even know upfront how many times you need it to repeat. To solve this, we can use a while loop.

A while loop tells the computer to keep executing a block of code as long as a certain condition evaluates to True. We've used Boolean conditions before with conditionals in a basic if statement. The computer evaluates the condition once and if it evaluates to true, it executes any code indented inside of it, and then it moves on to execute the rest of the program.

With a while loop, the computer evaluates the condition, and if it evaluates to true, the computer executes any lines of code indented inside of it. However, now that we're at what we call the bottom of the loop, the computer will go back to the condition and check it again. If it still evaluates to true, the computer will execute the lines of code indented inside the loop again, and so on, and so on, and so on. Until when the computer checks the condition, it finds that it evaluates to False. Only then does the loop terminate for good and the computer moves on to execute the rest of the program.

In Python, the syntax for a while loop is just the keyword while followed by a Boolean condition and then a colon. Any lines of code we want to repeat inside the while loop we indent one tab over. We call this the loop body. Because we want the loop to terminate eventually, we don't want it to repeat forever. We'll want the loop condition to evaluate to false at some point. Typically, that means our loop condition will include a loop variable, which is a variable that gets updated inside the loop body on each trip through the loop, what we call an iteration. The value of the variable will change, which means that when we go to check the loop condition again, there's a chance it might evaluate to false this time.

Let's take a look at our coin flip experiment. Here, we generate a random number between 1 and 2, and if that number is one, we print "heads," and if it's two, we print "tails." Now, what if I want to repeat that experiment to see how often I get tails? I can wrap my experiment in a while loop.

So, the first thing I'm going to want to do is figure out what my loop condition should be. Let's say I want to repeat this experiment five times, so my condition might be something like num_flips less than five. Then any lines of code I want to repeat need to be indented one level in. Well, on each iteration, I want to generate a new random number to simulate a coin flip, and then I still want to check if it's one or two and print heads or tails. So I'm going to tab all of these lines of code over.

If I run this program now, I get a name error because the variable num_flips hasn't been defined. We never assigned it a value. With while loops, we always want to make sure we initialize our loop variable before the loop. Here, we probably want to initialize num_flips to zero because we haven't done any coin flips yet. At this point, we have zero flips.

Now that our name error is fixed, it looks like the computer's printing heads, tails, tails, heads, heads forever. This is what we call an infinite loop. Our loop never terminates because our loop condition never evaluates to false. If you ever see your program hanging like this, you want to press the stop button to recover and terminate the program. Otherwise, it'll keep running forever until the computer runs out of memory.

So why is it infinite looping? Well, we never update the value of the loop variable inside the loop body. So num_flips always contains the value zero, which means every time we go back to the top and check the loop condition, we're checking if 0 is less than 5, which will always be true. What we actually want is to increment num_flips by one every time we flip a coin, so we're essentially counting up the number of flips.

Before the first iteration, num_flips will be zero. Then before the second iteration, it'll be one, two, three, and four until the check becomes five less than five, which evaluates to false, and the loop terminates. By convention, we update the loop variable at the very bottom of the loop so that it changes right before we go back to check the loop condition. Then we can increase our number of repetitions just by modifying this stop value in the loop condition, say to 100 or a thousand.

So when you're writing while loops, make sure you check for all three key components: that you initialize your loop variable before the loop, that you check your loop variable in the loop condition, and that you update the loop variable at the bottom of the loop body.

More Articles

View All
Searching For Life in Volcanoes and Other Extreme Environments | Nat Geo Live
JEFFREY MARLOW: As a scientist, we often go to some of the most extreme places on our planet to collect microbes, bring ‘em back, understand what they’re doing and how they work. These types of organisms can actually broaden our search for life beyond ear…
Tracing function calls | Intro to CS - Python | Khan Academy
What exactly happens when the computer executes a function call? Well, let’s trace a program with a function definition to find out. When we run the program, the computer, as normal, reads the program line by line starting at the top of the file. When th…
What Happens If A Star Explodes Near The Earth?
What would happen if a star exploded near the earth? Well, the nearest star to Earth, of course, is the sun, and it is not going to explode, but if it had eight times the mass, then it would go supernova at the end of its life. So what would that look lik…
Graphing parabola from quadratic in factored form
We’re asked to graph the equation ( Y = 12 \cdot x - 6 \cdot x + 2 ) and so, like always, pause this video and take out some graph paper or even try to do it on a regular piece of paper and see if you can graph this equation. Alright, now let’s work thro…
Office Hours at Startup School 2013 with Paul Graham and Sam Altman
We have to sit up straight. We have lower, since this is not right. Admiral Rickover would not stand for this. Um, okay. Uh, George, Nick, what are you working on? So we are building a multiplayer programming game for teaching people how to code. So lik…
Once You Get Money Upgrade These 15 Things Immediately
They lied to you. They told you to get the fast car, the diamond chain, the mansion. But deep down, you know those are just marketing campaigns to separate you from your hard-earned money. Do that, and you’ll be back to being broke in no time. But there a…