Week 8
Week 8
Problem Solving
and Algorithms
Chapter Goals
3
Problem Solving
Problem solving
The act of finding a solution to a perplexing,
distressing, vexing, or unsettled question
4
Problem Solving
5
Problem Solving
Ask questions!
– What do I know about the problem?
– What is the information that I have to process
in order the find the solution?
– What does the solution look like?
– What sort of special cases exist?
– How will I recognize that I have found
the solution?
7
Strategies
9
Computer Problem-Solving
10
Phase Interactions
Should we
add another
arrow?
(What happens
if the problem
is revised?)
11
Algorithms
Algorithm
A set of unambiguous instructions for solving a
problem or subproblem in a finite amount of time
using a finite amount of data
Abstract Step
An algorithmic step containing unspecified details
Concrete Step
An algorithm step in which all details are specified
12
Developing an Algorithm
13
Summary of Methodology
14
Top-Down Design
Control structure
An instruction that determines the order in
which other instructions in a program are
executed
Can you name the ones we defined in the
functionality of pseudocode?
16
Selection Statements
17
Algorithm with Selection
18
Algorithm with Selection
Determine Dress
IF (temperature > 90)
Write “Texas weather: wear shorts”
ELSE IF (temperature > 70)
Write “Ideal weather: short sleeves are fine”
ELSE IF (temperature > 50)
Write “A little chilly: wear a light jacket”
ELSE IF (temperature > 32)
Write “Philadelphia weather: wear a heavy coat”
ELSE
Write “Stay inside”
19
Looping Statements
20
Looping Statements
A count-controlled loop
Set sum to 0
Set count to 1
While (count <= limit)
Read number
Set sum to sum + number Why is it
Increment count called a
Write "Sum is " + sum count-controlled
loop?
21
Looping Statements
An event-controlled loop
Set sum to 0
Set allPositive to true
WHILE (allPositive) Why is it
Read number called an
IF (number > 0) event-controlled
Set sum to sum + number loop?
ELSE What is the
Set allPositive to false event?
Write "Sum is " + sum
22
Looping Statements
Read in square
Calculate the square root
Write out square and the square root
23
Looping Statements
Set epsilon to 1
WHILE (epsilon > 0.001)
Calculate new guess
Set epsilon to abs(square - guess * guess)
24
Looping Statements
Set newGuess to
(guess + (square/guess)) / 2.0
25
Looping Statements
Read in square
Set guess to square/4
Set epsilon to 1
WHILE (epsilon > 0.001)
Set guess to (guess + (square/guess)) / 2.0
Set epsilon to abs(square - guess * guess)
Write out square and the guess
26
Composite Data Types
Records
A named heterogeneous collection of items in
which individual items are accessed by name. For
example, we could bundle name, age and hourly
wage items into a record named Employee
Arrays
A named homogeneous collection of items in
which an individual item is accessed by its position
(index) within the collection
27
Composite Data Types
Employee
name
age
hourly/Wage
Following algorithm, stores values into the fields of record:
numbers[0]
numbers[4]
29
Arrays
30
An Unsorted Array
data[0]...data[length-1]
is of interest
31
Composite Data Types
Fill array numbers with limit values
integer data[20]
Write “How many values?”
Read length
Set index to 0
WHILE (index < length)
Read data[index]
Set index to index + 1
32
Sequential Search of an
Unsorted Array
A sequential search examines each item in turn
and compares it to the one we are searching.
If it matches, we have found the item. If not, we
look at the next item in the array.
We stop either when we have found the item or
when we have looked at all the items and not
found a match
Thus, a loop with two ending conditions
33
Sequential Search Algorithm
Set Position to 0
Set found to FALSE
WHILE (position < length AND NOT found )
IF (numbers [position] equals searchitem)
Set Found to TRUE
ELSE
Set position to position + 1
34
Booleans
Boolean Operators
A Boolean variable is a location in memory that can contain
either true or false
Boolean operator AND returns TRUE if both operands are
true and FALSE otherwise
Boolean operator OR returns TRUE if either operand is true
and FALSE otherwise
Boolean operator NOT returns TRUE if its operand is false
and FALSE if its operand is true
35
Sorted Arrays
The values stored in an array have unique keys of a
type for which the relational operators are defined
36
Sequential Search in a Sorted
Array
Is this better?
37
A Sorted Array
A sorted array of
integers
38
A Sorted Array
39
Binary Search
Sequential search
Search begins at the beginning of the list and
continues until the item is found or the entire list
has been searched
Binary search (list must be sorted)
Search begins at the middle and finds the item or
eliminates half of the unexamined items; process
is repeated on the half where the item might be
Say that again…
40
Binary Search
Set first to 0
Set last to length-1
Set found to FALSE
WHILE (first <= last AND NOT found)
Set middle to (first + last)/ 2
IF (item equals data[middle]))
Set found to TRUE
ELSE
IF (item < data[middle])
Set last to middle – 1
ELSE
Set first to middle + 1
RETURN found
41
Binary Search
45
Selection Sort
46
Selection Sort
47
Selection Sort
Selection Sort
Set firstUnsorted to 0
WHILE (not sorted yet)
Find smallest unsorted item
Swap firstUnsorted item with the smallest
Set firstUnsorted to firstUnsorted + 1
48
Bubble Sort
50
Insertion Sort
52
Subprogram Statements
53
Subprogram Statements
What if the subprogram needs data from the
calling unit?
Parameters
Identifiers listed in parentheses beside the
subprogram declaration; sometimes called formal
parameters
Arguments
Identifiers listed in parentheses on the
subprogram call; sometimes called actual
parameters
54
Subprogram Statements
56
Subprogram Statements
Value parameter
A parameter that expects a copy of its
argument to be passed by the calling unit
Reference parameter
A parameter that expects the address of its
argument to be passed by the calling unit
57
Subprogram Statements
Think of arguments as being placed on a message board
58
Recursion
Recursion
The ability of a subprogram to call itself
Base case
The case to which we have an answer
General case
The case that expresses the solution in terms of a
call to itself with a smaller version of the problem
59
Recursion
63
Quicksort
64
Important Threads
Information Hiding
The practice of hiding the details of a module with
the goal of controlling access to it
Abstraction
A model of a complex system that includes only
the details essential to the viewer
Control abstraction
–Control abstraction is like using a remote control for your TV.
You don't need to know how the TV's circuits and buttons work;
you just press a few buttons on the remote to change channels,
adjust the volume, or turn it on and off.
–In the world of computing, control abstraction means using
simple commands or functions to control complex actions in a
program without needing to understand all the intricate details of
how those actions are executed. It's like using a remote control
to interact with your TV, making it easier for you to manage and
control the program's behavior without delving into the technical
complexities.
66
Important Threads
Data abstraction
•Imagine you have a big, complicated machine, and you want
to use it without knowing all the tiny details about how it
works inside. Data abstraction in IT is like having a control
panel with simple buttons and switches that you can use to
operate the machine, without needing to understand the
complex machinery inside.
•In the same way, data abstraction hides the complicated inner
workings of computers and software. It gives you a user-
friendly way to work with data and programs without having
to worry about all the technical stuff happening in the
background. It makes things simpler and easier to use.
67
Important Threads
Procedural abstraction
–Imagine you want to bake a cake, but you don't need to
understand the science of heat and combustion to do it. Instead,
you follow a recipe that tells you what ingredients to use and the
steps to follow. You just need to know that when you set the
oven to a certain temperature and put your cake inside, it will
bake correctly. You don't have to worry about the inner
workings of the oven.
–In the same way, procedural abstraction in IT lets you use
complex functions or procedures in a computer program without
needing to understand every tiny detail of how they work. You
just need to know what input to give them and what result to
expect, just like following a recipe to bake a cake. This makes it
easier to use and work with software.
68
Important Threads
Identifiers
Names given to data and actions, by which
– we access the data and
Read firstName, Set count to count + 1
– execute the actions
Split(splitVal)
70
Who am I?
I was awarded
Knighthood in
1999.
What university
did I retire from
and where am
I working now?
71
Who am I?
George Polya
I am a
mathematician.
Why is my
picture in a
book about
computer
science?
72
Do you know?
73