8.1.1
Interpreting, Correcting & Completing Algorithm
Interpreting Algorithms
Interpreting Algorithms
Reading other peoples' code is sometimes the most difficult part of writing software, so it needs some practice.
data:image/s3,"s3://crabby-images/58812/5881244952a88fa38e0b766c5c8386badc8dc18d" alt="Illustrative background for Interpreting algorithms"
data:image/s3,"s3://crabby-images/58812/5881244952a88fa38e0b766c5c8386badc8dc18d" alt="Illustrative background for Interpreting algorithms ?? "content"
Interpreting algorithms
Interpreting algorithms
- Given an algorithm you should be able to read it and explain what it does.
- This needs some practice, but there are some things you can look out for.
data:image/s3,"s3://crabby-images/2daed/2daedfc7b6e003bc33a67046963f952820dc2d61" alt="Illustrative background for Look out for identifiers"
data:image/s3,"s3://crabby-images/2daed/2daedfc7b6e003bc33a67046963f952820dc2d61" alt="Illustrative background for Look out for identifiers ?? "content"
Look out for identifiers
Look out for identifiers
- Identifiers are the names of variables, constants, and subroutines.
- These often give strong clues about the purpose of an algorithm.
data:image/s3,"s3://crabby-images/6b9b0/6b9b01bcbe6463dfecf9965b7951b392b1aa01a8" alt="Illustrative background for Identify inputs and outputs"
data:image/s3,"s3://crabby-images/6b9b0/6b9b01bcbe6463dfecf9965b7951b392b1aa01a8" alt="Illustrative background for Identify inputs and outputs ?? "content"
Identify inputs and outputs
Identify inputs and outputs
- Check what is being input and output in the algorithm for clues about its purpose.
data:image/s3,"s3://crabby-images/8c3f0/8c3f01600a669f238687cdf7735c7853bbf9077e" alt="Illustrative background for Examine output messages"
data:image/s3,"s3://crabby-images/8c3f0/8c3f01600a669f238687cdf7735c7853bbf9077e" alt="Illustrative background for Examine output messages ?? "content"
Examine output messages
Examine output messages
- Output messages often format the result of an algorithm in a human readable way.
data:image/s3,"s3://crabby-images/ecc37/ecc373ba0347e02f0886ab4ab602781bbe3fb4fd" alt="Illustrative background for Look for comments"
data:image/s3,"s3://crabby-images/ecc37/ecc373ba0347e02f0886ab4ab602781bbe3fb4fd" alt="Illustrative background for Look for comments ?? "content"
Look for comments
Look for comments
- Comments are descriptions of the code.
- Comments will often state the purpose of a given algorithm.
- Comments are often the clearest way to identify an algorithm.
Correcting Algorithms
Correcting Algorithms
As well as knowing what an algorithm does, it's important to be able to fix it if it all goes wrong.
data:image/s3,"s3://crabby-images/1e1f2/1e1f2fba5cb1a9db976538ad6b8790dfef820c43" alt="Illustrative background for Incorrect identifiers",h_400,q_80,w_640.png)
data:image/s3,"s3://crabby-images/1e1f2/1e1f2fba5cb1a9db976538ad6b8790dfef820c43" alt="Illustrative background for Incorrect identifiers ?? "content",h_400,q_80,w_640.png)
Incorrect identifiers
Incorrect identifiers
- A common mistake in programs is incorrect identifiers.
- Be very careful with uppercase and lowercase letters.
- Be careful with similar looking characters:
- 0 and O.
- 1 and l (lower case L).
data:image/s3,"s3://crabby-images/ab5a5/ab5a5263bb8ca8f6db2ef25e1379b185b194d027" alt="Illustrative background for Incorrect operators"
data:image/s3,"s3://crabby-images/ab5a5/ab5a5263bb8ca8f6db2ef25e1379b185b194d027" alt="Illustrative background for Incorrect operators ?? "content"
Incorrect operators
Incorrect operators
- Look out for the difference between similar operators such as testing if a number is less than another, rather than less than or equal to the other.
data:image/s3,"s3://crabby-images/20f52/20f5279be8ee11fddce583e6b41d32609af2609f" alt="Illustrative background for Missing processes"
data:image/s3,"s3://crabby-images/20f52/20f5279be8ee11fddce583e6b41d32609af2609f" alt="Illustrative background for Missing processes ?? "content"
Missing processes
Missing processes
- Sometimes a line of code has been forgotten, which can lead to issues such as infinite loops, where the code will never end.
Completing Algorithms
Completing Algorithms
Some exam questions will ask you to state the output of an algorithm.
data:image/s3,"s3://crabby-images/4e996/4e9960ad6622da5212e600143ccc4b5564d52e76" alt="Illustrative background for Interpreting the algorithm"
data:image/s3,"s3://crabby-images/4e996/4e9960ad6622da5212e600143ccc4b5564d52e76" alt="Illustrative background for Interpreting the algorithm ?? "content"
Interpreting the algorithm
Interpreting the algorithm
- The first step for this type of question is to try to identify what the algorithm does.
- If you can interpret the algorithm, then it will be much easier to follow it.
data:image/s3,"s3://crabby-images/b4347/b43471044cac5baa090f3b3a7d44c9ff0052af24" alt="Illustrative background for Trace tables"
data:image/s3,"s3://crabby-images/b4347/b43471044cac5baa090f3b3a7d44c9ff0052af24" alt="Illustrative background for Trace tables ?? "content"
Trace tables
Trace tables
- You can draw a table with a column for each variable in the algorithm.
- Use this table to keep track of the value of each variable, and carefully follow through the code until the end.
- Finally, the trace table should include your answer.
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
Jump to other topics
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
data:image/s3,"s3://crabby-images/9220a/9220a64e707af924249b072e9ddcfcd413526ea9" alt="Go student ad image"
Unlock your full potential with GoStudent tutoring
Affordable 1:1 tutoring from the comfort of your home
Tutors are matched to your specific learning needs
30+ school subjects covered