Computational thinking, problem-solving and programming

  • Computational Thinking is a problem-solving method that involves breaking down complex problems into smaller, parts to find solutions using algorithms. 

  • Problem-solving is the process of finding solutions to complex issues. 

  • Programming is writing instructions for computers to execute tasks or solve problems.

1. Computation Thinking

  • Abstraction: Ignore irrelevant details to focus on essential aspects

  • Decomposition: Breaking down complex problems into smaller parts.

  • Pattern Recognition: Identifying similarities and differences within parts of a problem.

  • Algorithm Design: Create a series of steps to solve a problem.

The IB course requires that you learn and understand the following 6 prompts to help you solve problems while thinking and programming.

  • Thinking procedurally - divide and conquer by breaking up the problem into manageable parts, doing each one separately

  • Thinking logically - Making decisions and creating conditionals that affect those decisions

  • Thinking abstractly - Create a model to represent the problem

  • Thinking ahead - pre-planning

  • Thinking concurrently - dealing with multiple things at the same time

  • Thinking recursively - breaking down a complex problem into smaller parts and solving each part after the other until solved.

2. Program design

  • Program design is the process of planning and creating a structured set of instructions that a computer can follow to solve a specific problem efficiently, often involving algorithms and data structures.

  • There are typically three techniques used:

  1. Pseudocode: Writing code in a simple way before actual coding

  2. Flow charts: Visual diagrams showing the flow of a process or algorithm

  3. Trace tables: Tables used to track and record the values of variables

3. Standard Algorithms

The IB course requires you to memorize a couple of algorithms, there are the standard algorithms;

  • Sequential search: Linear search algorithm that checks each item in a list sequentially.

  • Binary search: Algorithm that divides the search interval in half at each step.

  • Bubble sort: A simple sorting algorithm that repeatedly steps through the list, compares adjacent elements, and swaps them if they are in the wrong order.

  • Selection sort: A sorting algorithm that selects the smallest element from the unsorted portion and swaps it with the first unsorted element.

4. Algorithm Efficiency

  • Algorithm Efficiency refers to how well an algorithm solves a problem. 

  • It is measured by time complexity (how long it takes to run) and space complexity (how much memory it uses). 

  • Common notations include O(n) for time complexity and O(1) for space complexity. 

  • There are four important rules you need to know when talking about algorithm efficiency.

  1. Add two important steps.

  2. Drop constants.

  3. different inputs use different variables

  4. Drop non-dominant terms

Programming concepts

There are many conventions in programming that most programmers should follow. These all improve the readability of the code, which can, in turn, save money, time, and effort for the programmers.

  1. Code layout - Code should follow indents and tabs between braces

  2. Comments - comments should be clear, common, and consistent

  3. Naming - naming should have the same consistency depending on what it is (class, variable, constant, method, etc)

  4. Functions - a function should only perform one job and you can use the function multiple times in the code if needed

High/Low-Level Languages
  • High-level languages: Use natural language elements making it easier for programmers to write code. Examples: Python, Java.

  • Low-level languages: Closer to machine code, more difficult for programmers. Examples: Assembly, Machine code.

robot