programming concept
programming concept
Computer Science
Programming Concepts
Contents
Variables & Constants
Data Types
Input & Output
Sequence
Selection
Iteration
Totalling & Counting
String Handling
Arithmetic, Logical & Boolean Operators
Procedures & Functions
Local & Global Variables
Library Routines
Maintaining Programs
Pseudocode
Python
What is a constant?
A constant is an identifier set once in the lifetime of a program
Constants are generally named in all uppercase characters
Constants aid the readability and maintainability
CONSTANT PI ← 3.142
Python
PI = 3.142
VAT = 0.20
PASSWORD = "letmein"
It is important to choose the correct data type for a given situation to ensure accuracy
and efficiency in the program
Data types can be changed within a program, this is called casting
Examples
Pseudocode (INPUT <identifier>) Python
What is an output?
An output is a value sent to an output device from a computer program
Typical output devices include:
Monitor - Displaying text, images or graphics
Speaker - Playing audio
Printer - Creating physical copies of documents or images
In programming the monitor is considered the standard for user output
If the command 'OUTPUT' is executed, a program will output to the screen
In other programming languages different command words can be used
OUTPUT "Love the name ", Name print("Love the name "+name)
Example 1
A simple program to ask a user to input two numbers, number two is subtracted from
number one and the result is outputted
Line Pseudocode
02 INPUT Num1
04 INPUT Num2
06 OUTPUT Result
A simple swap of line 01 and line 02 would lead to an unexpected behaviour, the user
would be prompted to input information without knowing what they should enter
Example 2
Python example
# ------------------------------------------------------------------------
# Main program
# ------------------------------------------------------------------------
length = 5
width = 3
correct_area = calculate_area(length, width)
print(f"Correct area (length * width): {correct_area}")
In the example, the sequence of instructions is wrong and would cause a runtime error
In the calculate_area() function a value is returned before it is assigned
The correct sequence is:
area = length * width
return area
If Statements
What is an If statement?
As If statements allow you to execute a set of instructions if a condition is true
They have the following syntax:
IF <condition>
THEN
<statement>
ENDIF
A detailed look at a Python IF statement:
Nested Selection
What is nested selection?
Nested selection is a selection statement within a selection statement, e.g. an If inside
of another If
Nested means to be 'stored inside the other'
Example
Pseudocode
Python
Case Statements
What is a case statement?
A case statement can mean less code but it only useful when comparing multiple values
of the same variable
If statements are more flexible and are generally used more in languages such as Python
The format of a CASE statement is:
CASE OF <identifier>
<value 1> : <statement>
<value 2>: <statement>
....
OTHERWISE <statement>
ENDCASE
Worked Example
Write an algorithm using pseudocode that:
Inputs 3 numbers
Outputs the largest of the three numbers
[3]
Exemplar answer
Pseudocode
INPUT A
INPUT B
INPUT C
IF A > B
THEN
IF A > C
THEN
OUTPUT A
ELSE
OUTPUT C
ENDIF
ELSE
OUTPUT B
ENDIF
Python
if A > B and A > C:
print(A)
elif B > C:
print(B)
else:
print(C)
Examples
Iteration Pseudocode Python
REPEAT
<statement>
UNTIL <condition>
WHILE <condition> DO
<statements>
ENDWHILE
A detailed look at a Python WHILE statement:
Nested Iteration
What is nested selection?
Nested iteration is a loop within a loop, e.g. a FOR inside of another FOR
Nested means to be 'stored inside the other'
Example
Pseudocode
Total ← 0
NEXT Row
Python
# Set the initial value of the counter for the outer loop
outer_counter = 1
# Inner loop to print the multiplication table for the current number
while inner_counter <= 10:
# Calculate the product of the outer and inner counters
product = outer_counter * inner_counter
Pseudocode Python
Total ← 0 total = 0
FOR I ← 1 to 10 for i in range(1, 11):
INPUT Num num = int(input("Enter a number: "))
TOTAL ← TOTAL + Num total = total + num
NEXT I print("Total:", total)
OUTPUT Total
Pseudocode Python
Count ← 0 count = 0
FOR I ← 1 to 10 for i in range(1, 11):
INPUT Num num = int(input("Enter a number: "))
IF Num > 5 if num > 5:
THEN count = count + 1
Count ← Count + 1 print("Count:", count)
ENDIF
NEXT I
OUTPUT Count
Worked Example
Write an algorithm using pseudocode that:
Inputs 20 numbers
Outputs how many of these numbers are greater than 50
[3]
Answer
Case conversion
The ability to change a string from one case to another, for example, lower case to
upper case
Length
The ability to count the number of characters in a string, for example, checking a
password meets the minimum requirement of 8 characters
Substring
Worked Example
The function Length(x) finds the length of a string x. The function substring(x,y,z) finds
a substring of x starting at position y and z characters long. The first character in x is in
position 1.
Write pseudocode statements to:
Store the string “Save my exams” in x
Find the length of the string and output it
Extract the word exams from the string and output it
[6]
Answer
X ← "Save my exams"
OUTPUT LENGTH(X)
# [1] for calling the function length. [1] for using the correct parameter X
Y←9
Z←5
OUTPUT SUBSTRING(X,Y,Z)
Arithmetic Operators
Operator Pseudocode Python
Addition + +
Subtraction - -
Multiplication * *
Division / /
# -----------------------------------------------------------------------
# Arithmetic operators #2
# -----------------------------------------------------------------------
# Get the radius from the user
radius = float(input("Enter the radius of the circle: "))
# ------------------------------------------------------------------------
# Arithmetic operators #3
# ------------------------------------------------------------------------
# Set the score to 0
score = 0
# Loop 5 times
for x in range(5):
num1 = int(input("Enter the first number: "))
operator = input("Enter the operator (+, -, *): ")
num2 = int(input("Enter the second number: "))
user_answer = int(input("What is " + str(num1) + " " + str(operator) + " " + str(num2) + "? "))
if user_answer == correct_answer:
score = score + 1
else:
print("Sorry, that's incorrect.")
Logical Operators
Operator Pseudocode Python
Equal to == ==
Boolean Operators
A Boolean operators is a logical operator that can be used to compare two or more
values and return a Boolean value (True or False) based on the comparison
There are 3 main Boolean values:
AND: Returns True if both conditions are True
OR: Returns True if one or both conditions are True
NOT: Returns the opposite of the condition (True if False, False if True)
To demonstrate the use of common Boolean operators, three sample programs written
in Python are given below
Comments have been included to help understand how the Boolean operators are
being used
Common Boolean operators #1 - a simple program that assigns Boolean values to
two variables and outputs basic comparisons
Common Boolean operators #2 - a simple program to output a grade based on a
users score
Common Boolean operators #3 - a simple program reads a text files and searches
for an inputted score
Python code
# -----------------------------------------------------------
# Common Boolean operators #2
# -----------------------------------------------------------
# Take input for the score from the user
score = int(input("Enter the score: "))
# -----------------------------------------------------------
# Common Boolean operators #3
# -----------------------------------------------------------
# Open the file for reading
try:
file = open("scores.txt", "r")
# While it's not the end of the file and the score has not been found
while not end_of_file and not found:
# Read the line
scores = file.readline().strip()
except FileNotFoundError:
print("The file 'scores.txt' was not found.")
Procedures
Procedures are defined using the PROCEDURE keyword in pseudocode or def keyword
in Python
A procedure can be written as:
PROCEDURE <identifier>
<statements>
ENDPROCEDURE
Or if parameters are being used:
Python
def ageCheck(age):
if age > 18:
print("You are old enough")
else:
print("You are too young")
CALL <identifier>
CALL <identifier>(Value1,Value2...)
Calling a procedure
Pseudocode
CALL Calculate_area
CALL Calculate_area(5,3)
Python
ageCheck(21)
print(ageCheck(21))
Examples
A Python program using procedures to display a menu and navigate between them
Procedures are defined at the start of the program and the main program calls the first
procedure to start
In this example, no parameters are needed
Procedures
# Main program
while True: # Loop to continuously show the menu until the user chooses to exit
main_menu()
Functions
Pseudocode
Python
def squared(number):
squared = number^2
return squared
Examples
A Python program using a function to calculate area and return the result
Two options for main program are shown, one which outputs the result (# 1) and one
which stores the result so that it can be used at a later time (# 2)
Functions
# Main program #2
length = int(input("Enter the length: ")) # Input for length
width = int(input("Enter the width: ")) # Input for width
calculated_area = area(length, width) # Stores the result of the function in a variable
print("The area is " + str(calculated_area) + " cm^2") # Outputs the result with a message
Worked Example
An economy-class airline ticket costs £199. A first-class airline ticket costs £595.
(A) Create a function, flightCost(), that takes the number of passengers and the type of
ticket as parameters, calculates and returns the price to pay.
You do not have to validate these parameters
You must use :
a high-level programming language that you have studied [4]
(B) Write program code, that uses flightCost(), to output the price of 3 passengers flying
economy.
You must use :
a high-level programming language that you have studied [3]
How do I answer this question?
(A)
Define the function, what parameters are needed? where do they go?
How do you calculate the price?
Return the result
(B)
How do you call a function?
What parameters does the function need to return the result?
Answers
Part Python
OR Your notes
x = flightCost("economy", 3)
print(x)
Python example
In this python code, you can see that the localVariable (with the value 10) is
declared inside of the function printValue
This means that only this function can access and change the value in the local variable
It cannot be accessed by other modules in the program
Local variables
def printValue():
localVariable = 10 # Defines a local variable inside the function
print("The value of the local variable is:", localVariable)
Global Variables
What is a global variable?
A global variable is a variable declared at the outermost level of a program.
They are declared outside any modules such as functions or procedures
Global variables have a global scope, which means they can be accessed and modified
from any part of the program
Python example
In this python code, you can see that the globalVariable (with the value 10) is
declared outside of the function printValue
This means that this function and any other modules can access and change the value in
the global variable
Global variables
Random
The random library is a library of code which allows users to make use of 'random' in their
programs
Examples of random that are most common are:
Random choices
Random numbers
Random number generation is a programming concept that involves a computer
generating a random number to be used within a program to add an element of
unpredictability
Examples of where this concept could be used include:
Simulating the roll of a dice
Selecting a random question (from a numbered list)
National lottery
Cryptography
number = random.randint(1,10)
number = random.randint(-1.0,10.0)
Examples in Python
Random code
National lottery
import random
ROUND(<identifier>, <places>)
def main():
# -----------------------------------------------------------------------
# Prompts the user for triangle base and height, calculates and prints the area
# -----------------------------------------------------------------------
try:
# ------------------------------------------------------------------------
# Main program
# ------------------------------------------------------------------------
main()