Lab 1: Population Growth
Labs are practice problems which, time permitting, may be started or completed in your section, and are assessed on correctness only. You are encouraged to collaborate with classmates on this lab, though each member in a group collaborating is expected to contribute equally to the lab.
Determine how long it takes for a population to reach a particular size.
$ ./population
Start size: 100
End size: 200
Years: 9
Background
Say we have a population of n
llamas. Each year, n / 3
new llamas are born, and n / 4
llamas pass away.
For example, if we were to start with n = 1200
llamas, then in the first year, 1200 / 3 = 400
new llamas would be born and 1200 / 4 = 300
llamas would pass away. At the end of that year, we would have 1200 + 400 - 300 = 1300
llamas.
To try another example, if we were to start with n = 1000
llamas, at the end of the year, we would have 1000 / 3 = 333.33
new llamas. We can’t have a decimal portion of a llama, though, so we’ll truncate the decimal to get 333
new llamas born. 1000 / 4 = 250
llamas will pass away, so we’ll end up with a total of 1000 + 333 - 250 = 1083
llamas at the end of the year.
Getting Started
Recall that Visual Studio Code (aka VS Code) is a popular “integrated development environment” (IDE) via which you can write code. So that you don’t have to download, install, and configure your own copy of VS Code, we’ll use a cloud-based version instead that has everything you’ll need pre-installed.
Log into code.cs50.io using your GitHub account. Once your “codespace” loads, you should see that, by default, VS Code is divided into three regions. Toward the top of VS Code is your “text editor”, where you’ll write all of your programs. Toward the bottom of is a “terminal window”, a command-line interface (CLI) that allows you to explore your codespace’s files and directories (aka folders), compile code, and run programs. And on the left is your file “explorer,” a graphical user interface (GUI) via which you can also explore your codespace’s files and directories.
Start by clicking inside your terminal window, then execute cd
by itself. You should find that its “prompt” resembles the below.
$
Click inside of that terminal window and then type
mkdir population
followed by Enter in order to make a directory called population
in your codespace. Take care not to overlook the space between mkdir
and population
or any other character for that matter!
Here on out, to execute (i.e., run) a command means to type it into a terminal window and then hit Enter. Commands are case-sensitive, so be sure not to type in uppercase when you mean lowercase or vice versa.
Now execute
cd population
to move yourself into (i.e., open) that directory. Your prompt should now resemble the below.
population/ $
Click inside of that terminal window and then type
wget https://cdn.cs50.net/2022/fall/labs/1/population.c
followed by Enter in order to download a template file called population.c
in your codespace. Take care not to overlook the space between wget
and the following URL, or any other character for that matter! If all was successful, you should execute
ls
and see a file named population.c
. Executing code population.c
should open the file where you will type your code for this lab. If not, retrace your steps and see if you can determine where you went wrong!
Implementation Details
Complete the implementation of population.c
, such that it calculates the number of years required for the population to grow from the start size to the end size.
- Your program should first prompt the user for a starting population size.
- If the user enters a number less than 9 (the minimum allowed population size), the user should be re-prompted to enter a starting population size until they enter a number that is greater than or equal to 9. (If we start with fewer than 9 llamas, the population of llamas will quickly become stagnant!)
- Your program should then prompt the user for an ending population size.
- If the user enters a number less than the starting population size, the user should be re-prompted to enter an ending population size until they enter a number that is greater than or equal to the starting population size. (After all, we want the population of llamas to grow!)
- Your program should then calculate the (integer) number of years required for the population to reach at least the size of the end value.
- Finally, your program should print the number of years required for the llama population to reach that end size, as by printing to the terminal
Years: n
, wheren
is the number of years.
Hints
-
If you want to repeatedly re-prompt the user for the value of a variable until some condition is met, you might want to use a
do ... while
loop. For example, recall the following code from lecture, which prompts the user repeatedly until they enter a positive integer.int n; do { n = get_int("Positive Integer: "); } while (n < 1);
How might you adapt this code to ensure a start size of at least 9, and an end size of at least the start size?
- To declare a new variable, be sure to specify its data type, a name for the variable, and (optionally) what its initial value should be.
- For example, you might want to create a variable to keep track of how many years have passed.
-
To calculate how many years it will take for the population to reach the end size, another loop might be helpful! Inside the loop, you’ll likely want to update the population size according to the formula in the Background, and update the number of years that have passed.
-
To print an integer
n
to the terminal, recall that you can use a line of code likeprintf("The number is %i\n", n);
to specify that the variable
n
should fill in for the placeholder%i
.
How to Test Your Code
Your program should behave per these examples below.
$ ./population
Start size: 1200
End size: 1300
Years: 1
$ ./population
Start size: -5
Start size: 3
Start size: 9
End size: 5
End size: 18
Years: 8
$ ./population
Start size: 20
End size: 1
End size: 10
End size: 100
Years: 20
$ ./population
Start size: 100
End size: 1000000
Years: 115
Execute the below to evaluate the style of your code using style50
.
style50 population.c
How to Submit
- Download your
population.c
file by control-clicking or right-clicking on the file in your codespace’s file browser and choosing Download. - Go to CS50’s Gradescope page.
- Click “Lab 1: Population”.
- Drag and drop your
population.c
file to the area that says “Drag & Drop”. Be sure it has that exact filename! If you upload a file with a different name, the autograder likely will fail when trying to run it, and ensuring you have uploaded files with the correct filename is your responsibility! - Click “Upload”.
You should see a message that says “Lab 1: Population submitted successfully!”
Per Step 4 above, after you submit, be sure to check your autograder results. If you see SUBMISSION ERROR: missing files (0.0/1.0)
, or some other error indicating a score of 0 points, it means your file was not named exactly as prescribed (or you uploaded it to the wrong problem).
Correctness in submissions entails everything from reading the specification, writing code that is compliant with it, and submitting files with the correct name. If you see this error, you should resubmit right away, making sure your submission is fully compliant with the specification. The staff will not adjust your filenames for you after the fact!
If you otherwise see a score less than the maximum, it means your submission is not fully correct. Best to review the feedback left by the autograder and consider making further adjustments!