
- Prolog Tutorial
- Prolog - Home
- Prolog - Introduction
- Prolog - Environment Setup
- Prolog - Hello World
- Prolog - Basics
- Prolog - Relations
- Prolog - Data Objects
- Prolog - Operators
- Loop & Decision Making
- Conjunctions & Disjunctions
- Prolog - Lists
- Recursion and Structures
- Prolog - Backtracking
- Prolog - Different and Not
- Prolog - Inputs and Outputs
- Prolog - Built-In Predicates
- Tree Data Structure (Case Study)
- Prolog - Examples
- Prolog - Basic Programs
- Prolog - Examples of Cuts
- Towers of Hanoi Problem
- Prolog - Linked Lists
- Monkey and Banana Problem
- Prolog Useful Resources
- Prolog - Quick Guide
- Prolog - Useful Resources
- Prolog - Discussion
Prolog - Loop & Decision Making
In this chapter, we will discuss loops and decision making in Prolog.
Loops
Loop statements are used to execute the code block multiple times. In general, for, while, do-while are loop constructs in programming languages (like Java, C, C++).
Code block is executed multiple times using recursive predicate logic. There are no direct loops in some other languages, but we can simulate loops with few different techniques.
Program
count_to_10(10) :- write(10),nl.count_to_10(X) :- write(X),nl, Y is X + 1, count_to_10(Y).
Output
| ?- [loop].compiling D:/TP Prolog/Sample_Codes/loop.pl for byte code...D:/TP Prolog/Sample_Codes/loop.pl compiled, 4 lines read - 751 bytes written, 16 ms(16 ms) yes| ?- count_to_10(3).345678910true ?yes| ?-
Now create a loop that takes lowest and highest values. So, we can use the between() to simulate loops.
Program
Let us see an example program −
count_down(L, H) :- between(L, H, Y), Z is H - Y, write(Z), nl. count_up(L, H) :- between(L, H, Y), Z is L + Y, write(Z), nl.
Output
| ?- [loop].compiling D:/TP Prolog/Sample_Codes/loop.pl for byte code...D:/TP Prolog/Sample_Codes/loop.pl compiled, 14 lines read - 1700 bytes written, 16 msyes| ?- count_down(12,17).5true ? ;4true ? ;3true ? ;2true ? ;1true ? ;0yes| ?- count_up(5,12).10true ? ;11true ? ;12true ? ;13true ? ;14true ? ;15true ? ;16true ? ;17yes| ?-
Decision Making
The decision statements are If-Then-Else statements. So when we try to match some condition, and perform some task, then we use the decision making statements. The basic usage is as follows −
If <condition> is true, Then <do this>, Else
In some different programming languages, there are If-Else statements, but in Prolog we have to define our statements in some other manner. Following is an example of decision making in Prolog.
Program
% If-Then-Else statementgt(X,Y) :- X >= Y,write('X is greater or equal').gt(X,Y) :- X < Y,write('X is smaller').% If-Elif-Else statementgte(X,Y) :- X > Y,write('X is greater').gte(X,Y) :- X =:= Y,write('X and Y are same').gte(X,Y) :- X < Y,write('X is smaller').
Output
| ?- [test].compiling D:/TP Prolog/Sample_Codes/test.pl for byte code...D:/TP Prolog/Sample_Codes/test.pl compiled, 3 lines read - 529 bytes written, 15 msyes| ?- gt(10,100).X is smalleryes| ?- gt(150,100).X is greater or equaltrue ?yes| ?- gte(10,20).X is smaller(15 ms) yes| ?- gte(100,20).X is greatertrue ?yes| ?- gte(100,100).X and Y are sametrue ?yes| ?-