KEMBAR78
Module 3-1 | PDF | Algorithms | Heuristic
0% found this document useful (0 votes)
16 views9 pages

Module 3-1

The document discusses methods for solving computing problems, focusing on two primary approaches: algorithms and heuristics. Algorithms provide precise, step-by-step instructions for problem-solving, while heuristics offer quicker, intuitive solutions that may not guarantee optimal results. It also classifies problems as solvable or unsolvable, detailing techniques for effective problem-solving, including abstraction, brainstorming, and divide and conquer.

Uploaded by

ifeoluwafatogun1
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
16 views9 pages

Module 3-1

The document discusses methods for solving computing problems, focusing on two primary approaches: algorithms and heuristics. Algorithms provide precise, step-by-step instructions for problem-solving, while heuristics offer quicker, intuitive solutions that may not guarantee optimal results. It also classifies problems as solvable or unsolvable, detailing techniques for effective problem-solving, including abstraction, brainstorming, and divide and conquer.

Uploaded by

ifeoluwafatogun1
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 9

METHODS OF SOLVING COMPUTING PROBLEMS

Solving computing problems involves a structured approach to identify, analyze, and resolve
issues. Here, we will discuss two major approaches such as Algorithm and Heuristics.
Algorithm
An algorithm is a precise set of rules or procedures for solving a problem or completing a
specific task. It is a problem-solving formula that provides you with step-by-step instructions
used to achieve a desired outcome. An algorithm is usually known to consist of a sequence of
steps with a starting point and a known endpoint which do not depend on intuition or guesses,
but rather provide instructions to obtain a solution. Therefore, algorithms guarantee that the
given set of rules will ultimately lead us to the correct answer. Algorithms are also said to be
precise, and this makes them suitable for use in various areas of computer science. They are used
to produce outputs from a given set of inputs.

You can think of an algorithm as a recipe with highly detailed instructions that produce
the same result every time they are performed. Algorithms are used frequently in our
everyday lives, especially in computer science. When you run a search on the Internet,
search engines like Google use algorithms to decide which entries will appear first in
your list of results. Facebook also uses algorithms to decide which posts to display on
your newsfeed. Can you identify other situations in which algorithms are used?

Heuristic
Heuristics usually refers to a technique for problem-solving. They’re used when classical
approaches are time consuming, as well as when an appropriate solution can’t be found
with a classical approach. In other words, they allow us to quickly obtain an appropriate
solution to a problem through exploration, intuition, and sometimes an educated guess. As such,
heuristics begin by exploring possible solutions to a problem. The first step is to search the
solution space to find an area in which the solution might be located. Then the search for a
solution is focused on this area.

The goal here is to obtain an acceptable solution to a problem in a timely manner. As a result, the
solution obtained isn’t necessarily the best or most precise solution. This is known as a trade-
off between precision and speed.

In addition to the precision-speed trade-off, there are other points to consider, such as:
 completeness – are all the possible solutions found?
 optimality – is the solution the best solution?

Furthermore, heuristics can’t be mathematically proven because the methodology used to solve
problems is often based on intuition and explorations. Consequently, they can not be replicated
by other users, and won’t always yield the same results.

While an algorithm must be followed exactly to produce a correct result, a heuristic is a general
problem-solving framework. You can think of these as mental shortcuts that are used to solve
problems.

Different types of heuristics are used in different types of situations, but the impulse to
use a heuristic occurs when one of five conditions is met:
 When one is faced with too much information
 When the time to make a decision is limited
 When the decision to be made is unimportant
 When there is access to very little information to use in making the decision
 When an appropriate heuristic happens to come to mind in the same moment

Working backwards is a useful heuristic in which you begin solving the problem by focusing on
the end result. It is common to use the working backwards heuristic to plan the events of your
day on a regular basis, probably without even thinking about it. Another useful heuristic is the
practice of accomplishing a large goal or task by breaking it into a series of smaller steps.
Students often use this common method to complete a large research project or long essay for
school. For example, students typically brainstorm, develop a thesis or main topic, research the
chosen topic, organize their information into an outline, write a rough draft, revise and edit the
rough draft, develop a final draft, organize the references list, and proofread their work before
turning in the project. The large task becomes less overwhelming when it is broken down into a
series of small steps.

Applications of Heuristics
Heuristics are attractive because they find solutions in a timely manner. Therefore, they’re
suitable for use in optimization problems and algorithms. To better understand this, let’s discuss
some of its applications:
1. Traveling Salesperson Problem
The Traveling Salesperson Problem (TSP) is an optimization problem in which the objective is
to find an optimal route between a set of nodes. The question is, given a set of cities (nodes) and
distances between these cities, what is the shortest possible route that visits each city:

The TSP problem is difficult to solve and is often classified as NP-hard. In other words, it’s
complex and hard to verify. However, heuristics help us here to approximate an optimal route to
all the cities.

2. Greedy Algorithms

Greedy algorithms attempt to find locally optimal solutions at each stage in solving a problem.
To clarify, the assumption is that a set of locally optimal solutions may eventually lead to a
globally optimal solution in the end. Hence, they’re often applied to the TSP problem we just
discussed.

3. Antivirus Software
When scanning for viruses, heuristics are used to search for samples of code that resemble
viruses in files. This significantly reduces the number of files that have to be searched for
viruses.

Some additional applications of heuristics include searching, simulated annealing, and hill-
climbing.
Difference between Algorithm and Heuristics
 Precision: Algorithms provide precise solutions, while heuristics offer
approximate solutions.
 Guarantee: Algorithms guarantee a solution, whereas heuristics do not.
 Complexity: Algorithms can be complex and time-consuming, while heuristics
are generally simpler and faster.
It’s important to note that a heuristic can also be an algorithm in the sense that it describes how
to solve a problem. However, the major differences can be summed up as follows:

Heuristic Algorithm

It’s based on intuition, guesses, or explorations It’s based on a finite set of instructions

Will usually yield a sub-optimal result; however,


Guaranteed to yield an optimal result
optimal results are possible

Cannot be proven mathematically; however, this


Can be mathematically proven
isn’t always the case

Won’t yield the same answer every time, thus not Will always yield the same answer, thus
reproducible they’re reproducible

SOLVABLE AND UNSOLVABLE PROBLEMS

In computer science and mathematics, problems can be classified as solvable or unsolvable


based on whether there exists an algorithm that can provide a solution.
Solvable Problems
A problem is said to be solvable first either if you find a solution means what there, you have
its solution. A problem is considered solvable if there exists a potential solution such as an
algorithm or procedure to find its solution in a finite amount of time. We can also say the
problem is solvable if you proved mathematically there exists no solution which means the
problem does not require any further discussion because we know the problem can never be
solvable no matter how many times, we try to solve the problem.
Examples include:
 Sorting algorithms: Algorithms like QuickSort or MergeSort can sort a list of
numbers.
 Searching algorithms: Algorithms like Binary Search can find an element in a
sorted list.
 Mathematical computations: Problems like finding the greatest common
divisor (GCD) of two numbers.

Unsolvable Problems

Unsolvable problems in computer science is a temporary status of the problem because a


problem is unsolvable, we say that instant of time neither we are able to solve the problem
nor in a position to say that the problem cannot be solved which means in unsolvable
problems we are still confused, and the discussion is still open. And if the problem lies in
this domain so it is known as an unsolvable problem.

Unsolvable problems, also known as undecidable problems, are those for which no algorithm
can provide a solution for all possible inputs. Examples include:

 The Halting Problem: Determining whether a given program will halt or run
forever on a given input.
 The Entscheidungsproblem: Determining whether a given statement in first-
order logic is universally valid.

These classifications are crucial in understanding the limits of computation and help in
identifying which problems can be tackled with algorithms and which cannot.
Basically, the solvable problems are divided into two categories – Decidable and Undecidable.
Before going into the depth of the decidability domain, we should have a good knowledge of
algorithms and machine models of the Theory of Computation , especially the Turing
Machines.
 Decidable Problem :
When we talk about the decidable problems the two important terms are used algorithms and
procedures. The procedure is a step-by-step instruction to solve a problem. A procedure
becomes an algorithm when we say what is the approximate time to solve a problem. When we
are concern with decidable problems means it includes both algorithms as well as procedures.
 Undecidable Problem :
When we talk about undecidable problems then we can not predict the time of the problem in
which a problem can be solved. Undecidable problems are also solvable and there exists a
procedure to solve the problem, but the problem is complex as we cannot predict the
approximate time.

PROBLEM SOLVING TECHNIQUES


There are several effective techniques for problem solving, each suited to different types of
problems and contexts. Here are some widely used methods:

1. Abstraction: refers to solving the problem within a model of the situation before applying
it to reality.

2. Analogy: is using a solution that solves a similar problem. That is when one Draws
parallels between the current problem and a similar one that has been solved before. For
example, using the structure of a known algorithm to solve a new, but related,
problem.

3. Brainstorming: refers to collecting and analyzing a large amount of solutions, especially


within a group of people, to combine the solutions and developing them until an optimal
solution is reached. It is also the process of Generating a wide range of ideas without
immediate judgment to explore possible solutions.
For example, in a team setting, everyone contributes ideas for a new software
feature.
4. Trial and Error: A trial-and-error approach to problem-solving involves trying a number
of different solutions and ruling out those that do not work. This approach can be a good
option if you have a very limited number of options available. In terms of a broken
printer for example, one could try checking the ink levels, and if that doesn’t work, you
could check to make sure the paper tray isn’t jammed. Or maybe the printer isn’t actually
connected to a laptop. When using trial and error, one would continue to try different
solutions until the problem is solved. Although trial and error is not typically one of the
most time-efficient strategies, but it is a commonly used one. For example, testing
various configurations to optimize a network setup.
5. Hypothesis Testing: This a method used in experimentation where an assumption about
what would happen in response to manipulating an independent variable is made, and
analysis of the effects of the manipulation are made and compared to the original
hypothesis. In summary, we formulate hypotheses and test them through experiments or
simulations. For example, In machine learning, we test different models to find the best
fit for the data.

6. Reduction: This is the Breaking down of a complex problem into simpler sub-problems
that are easier to solve. For example, Decomposing a large software project into smaller,
manageable modules.

7. Literal Thinking: This is the act of focusing on the exact meaning of the problem
without interpreting it abstractly. For example, Following a recipe step-by-step without
making any assumptions.

8. Means-End Analysis: choosing and analyzing an action at a series of smaller


steps to move closer to the goal. That is, Comparing the current state to the
goal state and take steps to reduce the difference.

This strategy involves choosing and analyzing an action at a series of smaller steps to
move closer to the goal. One example of means-end analysis can be found by using the
Tower of Hanoi paradigm. This paradigm can be modelled as a word problem.

The actual Tower of Hanoi problem consists of three rods sitting vertically on a base with
a number of disks of different sizes that can slide onto any rod. The puzzle starts with the
disks in a neat stack in ascending order of size on one rod, the smallest at the top making
a conical shape. The objective of the puzzle is to move the entire stack to another rod
obeying the following rules:
i. Only one disk can be moved at a time.

ii. Each move consists of taking the upper disk from one of the stacks and placing it on top
of another stack or on an empty rod.
iii. No larger disc may be placed on top of a smaller disk.
With 3 disks, the puzzle can be solved in 7 moves. The minimal moves required to solve
a Tower of Hanoi puzzle is 2n – 1, where 𝑛 is the number of disks. For example, if there
were 14 disks in the tower, the minimum amount of moves that could be made to solve
the puzzle would be 214 – 1 = 16,383 moves. There are various ways of approaching the
Tower of Hanoi or its related problems in addition to the approaches listed above
including an iterative solution, recursive solution, non-recursive solution, a binary and
Gray-code solutions, and graphical representations. For example, In AI, using this
technique to plan actions that lead to a desired outcome.

9. Method of Focal Object: putting seemingly non-matching characteristics of different


procedures together to make something new that will get you closer to the goal. This is
done by Combining attributes of different objects to generate new ideas.
For example: Innovating a new product by merging features of existing ones.

10. Morphological Analysis: analyzing the outputs of and interactions of many pieces that
together make up a whole system. It explores all possible solutions by systematically
varying parameters. For example, designing a new product by considering all
combinations of features.

11. Research: using existing knowledge or solutions to similar problems to solve the problem.
Gather information from various sources to understand the problem better.
Example: Conducting a literature review before starting a research project.

12. Root Cause Analysis: trying to identify the cause of the problem. That is, Identifying the
underlying cause of a problem rather than just addressing symptoms.
• Example: Using the “5 Whys” technique to find the root cause of a
manufacturing defect.

13. Proof: This is when trying to prove that a problem cannot be solved. Where the proof
fails, becomes the starting point or solving the problem, using logical reasoning to
demonstrate that a solution is correct. For example, Proving the correctness of an
algorithm through mathematical induction.
14. Divide and Conquer: breaking down large complex problems into smaller more
manageable problems or Splitting the problem into smaller, independent parts and solve
each part separately. For example, Implementing the Merge Sort algorithm, which
divides the array into halves.

You might also like