Basic Features#
Algorithms are the commands that make up our programs.
There are 6 basic building blocks that an algorithm consists of. Each of them serve a particular purpose.
Sequence: a number of instructions that are processed one after the other.
Assignment: used to store the value of an expression into a variable.
Condition: the way that a computer asks a question which can only generate two possible responses:
True
(yes) orFalse
(no).Selection: a statement that uses a condition to select, or determine, whether the next line of the program is to be executed.
Iteration: the repetition of a number of instructions. These are generally referred to as loops and refer to a section of code that is repeated.
Modularisation: refers to the process of breaking a large, unwieldy programming task into separate, smaller, more manageable subtasks or modules. Individual modules can then be cobbled together like building blocks to create a larger application.
In designing your algorithm, you will need to decide how to arrange these building block to achieve you outcome. To do this it is wise to follow good programming practices.
Variables#
Variables are the names you give to computer memory locations which are used to store values in a computer program. Variables can store data of different types, and different variable types can do different things.
Types#
Variable can be of different types. The type of a variable indicates the what kind of data is stored at that memory location.
In programming languages, there are two different type variable systems:
dynamic: type checking only occurs as the code runs, and the type of a variable is allowed to change over its lifetime.
static: type checks are performed without running the program. In most statically typed languages this is done as your program is compiled. The type of a variable is not allowed to change over its lifetime.
Python is a dynamically typed language. This means that you can store any type of data in a variable, irrespective of the type of data that is already stored there.
The Python data types that we will be using are:
Strings:
strings are sequences of character data
the string type in Python is called
str
string literals may be delimited using either single or double quotes
Integers:
integers are whole numbers
the integer type in Python is called
int
there is effectively no limit to how long an integer value can be, but it is constrained by the amount of memory your system has.
Floating-Point Numbers:
float values are numbers specified with a decimal point
the
float
type in Python designates a floating-point numberoptionally, the character e or E followed by a positive or negative integer may be appended to specify scientific notation
Boolean Type:
objects of Boolean type may have one of two values,
True
orFalse
the Boolean type in Python is called
bool
a value that is true in Boolean context is sometimes said to be “truthy” and one that is false in Boolean context is said to be “falsy”
the “truthiness” of an object of Boolean type is self-evident: Boolean objects that are equal to
True
are truthy (true), and those equal toFalse
are falsy (false)
Scope: Local and Global Variables#
In programming, the scope of a name defines the area of a program in which you can unambiguously access that name, such as variables, functions, objects, and so on. A name will only be visible to and accessible by the code in its scope. Several programming languages take advantage of scope for avoiding name collisions and unpredictable behaviours. Most commonly, you’ll distinguish two general scopes:
Global scope: The names that you define in this scope are available to all your code.
Local scope: The names that you define in this scope are only available or visible to the code within the scope.
Scope came about because early programming languages (like BASIC) only had global names. With this kind of name, any part of the program could modify any variable at any time, so maintaining and debugging large programs could become a real nightmare. To work with global names, you’d need to keep all the code in mind at the same time to know what the value of a given name is at any time. This was an important side-effect of not having scopes.
Some languages like Python use scope to avoid this kind of problem. When you use a language that implements scope, there’s no way for you to access all the variables in a program at all locations in that program. In this case, your ability to access a given name will depend on where you’ve defined that name.
Using the LEGB Rule for Python Scope#
Python resolves names using the so-called LEGB rule, which is named after the Python scope for names. The letters in LEGB stand for Local, Enclosing, Global, and Built-in. Here’s a quick overview of what these terms mean:
Local (or function) scope: the code block or body of any Python function or lambda expression. This Python scope contains the names that you define inside the function. These names will only be visible from the code of the function. It’s created at function call, not at function definition, so you’ll have as many different local scopes as function calls. This is true even if you call the same function multiple times, or recursively. Each call will result in a new local scope being created.
Enclosing (or nonlocal) scope: a special scope that only exists for nested functions. If the local scope is an inner or nested function, then the enclosing scope is the scope of the outer or enclosing function. This scope contains the names that you define in the enclosing function. The names in the enclosing scope are visible from the code of the inner and enclosing functions.
Global (or module) scope: the top-most scope in a Python program, script, or module. This Python scope contains all of the names that you define at the top level of a program or a module. Names in this Python scope are visible from everywhere in your code.
Built-in scope: a special Python scope that’s created or loaded whenever you run a script or open an interactive session. This scope contains names such as keywords, functions, exceptions, and other attributes that are built into Python. Names in this Python scope are also available from everywhere in your code. It’s automatically loaded by Python when you run a program or script.
The LEGB rule is a kind of name lookup procedure, which determines the order in which Python looks up names. For example, if you reference a given name, then Python will look that name up sequentially in the local, enclosing, global, and built-in scope. If the name exists, then you’ll get the first occurrence of it. Otherwise, you’ll get an error.
Scope limitations on actions#
Action |
Global Code |
Local Code |
Nested Function Code |
---|---|---|---|
Access or reference names that live in the global scope |
Yes |
Yes |
Yes |
Modify or update names that live in the global scope |
Yes |
No (unless declared global) |
No (unless declared global) |
Access or reference names that live in a local scope |
No |
Yes (its own local scope),No (other local scope) |
Yes (its own local scope), No (other local scope) |
Override names in the built-in scope |
Yes |
Yes (during function execution) |
Yes (during function execution) |
Access or reference names that live in their enclosing scope |
N/A |
N/A |
Yes |
Modify or update names that live in their enclosing scope |
N/A |
N/A |
No (unless declared nonlocal) |
Control Structures#
Flow of control through any given function is implemented with three basic types of control structures:
Sequential#
In sequential code, the program executes the first line, then the next line, then the next. This continues until there are no lines of code left.
Conditions#
A condition is the way that a computer asks a question. Computers can only generate two possible responses to questions. Yes and No, or more precisely, True and False. A more formal definition is that a condition is a logical expression that evaluates to true or false.
In Python conditions are part of if
and while
statements. They have the syntax of value
operator
value
with six possible operators:
Equals: a == b
Not Equals: a != b
Less than: a < b
Less than or equal to: a <= b
Greater than: a > b
Greater than or equal to: a >= b
Selection#
The selection control structure is where the program splits into alternative paths depending on condition results. In a selection block, program can only take one of the paths offered, it will skip the other paths. Once the selection block is complete, the program will continue with the first line of code immediately after the selection block. This is also called branching, because it has a similar forking process of a tree or a river.
In Python there are two main type of branching:
if ... elif ... else
statements:”The structure of a full
if … elif … else
statement is:the
if
componentalways at the beginning of an
if … elif … else
statementthe only compulsory component
there can only be one
if
perif … elif … else
statement
the
elif
componentmust come after the
if
statement and before theelse
statementis optional
there can be as many
elif
components as neededit is only used when all the conditions before it are
False
the
else
componentmust be at the end of an an
if … elif … else
statementit is optional
there can only be one per
if … elif … else
statementit is only used when all the conditions before it are
False
match case
statement:takes a variable and attempts to match it to various options
similar to the
switch
statements in other languagesintroduced in Python 3.10
Iteration#
Iteration control structures, also called loops, repeat a block of code, with a minor change each time. There are three types of iteration control structures:
indefinite iteration — used when you don’t know how many times the loop will need to run
pre-test loops (WHILE loops) will check if a condition is
True
before executing the loop’s code blockpost-test loop (REPEAT loops) will execute the loop’s code block and then check is a condition is
True
definite iteration — used when you do know how many times the loop will need to run.
counted loop (FOR loops) will execute a loop a specific number of times.
Python does not have a post-test loop structure. The iteration control structures in Python are:
while
loopstart with a condition test
repeats the code block until the condition test is
False
for
loopis provided with a Python iterable
will take the first item from the iterable and use it to execute the code block
will then move onto the next item in the iterable, until there are no items left.
What is an iterable
In Python, an iterable is a container that holds things. You can go through each thing inside one at a time, like flipping through the pages of a book. The Python iterables available available by default are lists, tuples, strings, dictionaries, and sets.
Data Structures#
Data structures are used to store data in an organized form. No matter what problem are you solving, in one way or another you have to deal with data — whether it’s an employee’s salary, stock prices, a grocery list, or even a simple telephone directory. [ul Haq, 2018]
The best way to understand of data structures is to think of them as collections of related data. For example, a collection of shopping items, or a collection of contacts with phone numbers.
In Python we will deal with four data structures:
Lists:
lists are defined as an ordered collection of items
they are one of Python’s essential data structures
list are defined using square brackets
[
]
to enclose the elements, which are separated by commasFor example,
[1,2,3,4]
.each element in the list is referred to by its index (position number), starting at 0.
Tuples:
Tuples are also an ordered collection of objects, but unlike lists, they come with limited functionality.
The primary differing characteristic between lists and tuples is that lists are mutable, whereas tuples are immutable. This means tuples cannot be modified, added, or deleted once they’ve been created.
tuples are defined by using parentheses
(
)
to enclose the elements, which are separated by commasFor example,
(1,2,3,4)
.
each element in the tuple is referred to by its index (position number), starting at 0.
reasons for using tuples instead of lists:
when the developer does not want the data to be modified
when speed is important as tuples use less memory, and they make program execution faster
Sets:
sets are a collection of unique elements that do not follow a specific order.
they are mutable – they can be modified, added, replaced, or removed
sets are defined by using curly brackets
{
}
to enclose the elements, which are separated by commasFor example,
{1,2,3,4}
.
they are used when the existence of an object in a collection of objects is more important than the number of times it appears or the order of the objects.
Dictionaries:
dictionaries are an ordered collection of key-value pairs. Each key-value pair maps the key to its associated value
they are mutable – they can be modified, added, replaced, or removed.
dictionaries are defined by using curly brackets
{
}
to enclose the elements, with a colon:
separating a key and its value, and each key-pair separated by commasFor example,
{"Doh":"Doherty","Dun":"Dunlop","Fly":"Flynn","Nic":"Nichols"}
they should be used when the data has a unique reference that can be associated with the value.
Syntax#
The syntax of a computer language is the set of rules that defines the combinations of symbols that are considered to be correctly structured statements or expressions in that language.
Libraries#
A software library refers to a collection of files, programs, routines, scripts, or functions referenced in the programming code. Python comes with a standard library which provides basic functionality. Python allows you to install additional libraries, as well as create your own. We are installing additional libraries when we use pip
.
Classes#
Classes and object are basic building blocks in object-oriented programming languages. A class is written by a programmer in a defined structure to create an object in an object-oriented programming language. It defines a set of attributes and methods that are common to all objects of one type.
For example, a class could be a car, which could have a colour attribute, four tire attributes, and a drive method.
Another related class could be a truck, which would have similar attributes, but not be exactly the same as a car.
Both a car and a truck could be a kind of a third class which could be called a vehicle class. In this way, the programmer could create the parts of the program that are the same for both the car and the truck in programming the vehicle class, yet the programmer would be free to program how a car is different from a truck without duplicating all of the programming.
Although there is only one class called “car”, there could be many objects that are created from the class called “car”. And, although there is only one class that is called “truck”, many objects of type truck could be created from this class. The class, vehicle, is actually general and there would probably not be any objects that were only of the class “vehicle”.
Inside of classes are two kinds of things:
attributes: store data; you could have a colour attribute, a speed attribute and a size attribute.
methods: can store the code for doing actions; in this example you could have a drive method and a brake method, and maybe a turn_right and turn_left method.
You can call methods by first making an object of the Car or Truck class, and call it for example ferrari
, and doing ferrari.method_name()
. In this case, if we wanted to make the vehicle move, we could do ferrari.drive(distance)
.
We learnt about classes and object orientated programming in the Deepest Dungeon course.
Operations#
Operators are used to perform operations on variables and values.
Python divides the operators in the following groups:
Arithmetic operators
Assignment operators
Comparison operators
Logical operators
Identity operators
Membership operators
Bitwise operators
Arithmetic Operators#
Arithmetic operators are used with numeric values to perform common mathematical operations.
Operator |
Name |
Example |
---|---|---|
|
Addition |
|
|
Subtraction |
|
|
Multiplication |
|
|
Division |
|
|
Modulus |
|
|
Exponentiation |
|
|
Floor division |
|
In Python addition, subtraction, and multiplication are all strait forward and do exactly like you would expect. Note: that brackets (
and )
work the same as they would in mathematical equations.
It is worth checking out how division, modulus, floor division and exponentiation work.
Assignment Operators#
The standard assignment operator =
is used to assign values to a variable.
Operator |
Example |
Same As |
---|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The other assignment operators +=
, -=
, *=
, etc. adjust a variable by operation sign and the value provided.
Comparison Operators#
Comparison operators are used to compare two values, and will return a value of True
or False
.
Operator |
Name |
Example |
---|---|---|
|
Equal |
|
|
Not equal |
|
|
Greater than |
|
|
Less than |
|
|
Greater than or equal to |
|
|
Less than or equal to |
|
Comparisons can be between values, variables, calculations or even the results of a function call.
Logical Operators#
Logical operators are used to combine conditional statements. The truthiness of the conditions is tested, and then operator combines the resulting Boolean values to produce either True
or False
.
Operator |
Description |
Example |
---|---|---|
|
Returns |
|
|
Returns |
|
|
Reverse the result, returns |
|
Identity Operators#
Identity operators are used to compare the objects, not if they are equal, but if they are actually the same object, with the same memory location.
Operator |
Description |
Example |
---|---|---|
|
Returns |
|
|
Returns |
|
Membership Operators#
Membership operators are used to test if a sequence is presented in an object (list, tuple or string).
Operator |
Description |
Example |
---|---|---|
|
Returns |
|
|
Returns |
|
Bitwise Operators#
Bitwise operators are used to compare (binary) numbers. Realistically we are not going to use these, but it worth knowing they exist in case you come across them in some code.
Operator |
Name |
Description |
---|---|---|
& |
AND |
Sets each bit to 1 if both bits are 1 |
/ |
OR |
|
^ |
XOR |
Sets each bit to 1 if only one of two bits is 1 |
~ |
NOT |
Inverts all the bits |
<< |
Zero fill left shift |
Shift left by pushing zeros in from the right and let the leftmost bits fall off |
>> |
Signed right shift |
Shift right by pushing copies of the leftmost bit in from the left, and let the rightmost bits fall off |
Unit 1 subject matter covered:
Recognise and describe programming syntax and rules.
Understand the five basic features of programming – variables, control structures, data structures, syntax and libraries and classes.
Identify and describe the purpose of code syntax and rules.
Identify and describe the scope and use of local and global variables [QCAA, 2017]