Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Intelligence
Practical
File
Submitted By:
Chetan Verma(16HCS4415)
INDEX
Name: Roll No:16HCS44
9. Consider a cyclic directed graph [edge (p, q), edge (q, r), edge (q, r),
edge (q, s), edge (s,t)] where edge (A,B) is a predicate indicating
directed edge in a graph from a node A to a node B. Write a program
to check whether there is a route from one node to another node.
11. Write a Prolog program to implement conc (L1, L2, L3) where L2 is
the list to be appended with L1 to get the resulted list L3.
12. Write a Prolog program to implement reverse (L, R) where List L is
original and List R is reversed list.
23. Write a program in PROLOG to implement merge (L1, L2, L3) where
L1 is first ordered list, L2 is second ordered list, and L3 represents the
merged list.
24. Write a PROLOG program that will take grammar rules in the
following format:
NT ->(NT | T)*
Where NT is any nonterminal, T is any terminal and Kleene star (*)
signifies any number of
repetitions, and generate the corresponding top-down parser, that
is:
sentence -> noun-phrase, verb-phrase
determiner -> [the]
will generate the following:
sentence (I, O) :- noun-phrase(I,R), verb-phrase (R,O).
determiner ([the|X], X) :- !.
Q1.Write a prolog program to calculate the sum of two numbers.
sum(X,Y,S):- S is X+Y.
max(X,Y,M):- X>Y, M is X.
max(_,Y,M):- M is Y.
factorial(0,1).
factorial(N,X):- N1 is N-1,
factorial(N1,X1),
X is X1*N.
Q4. Write a program in PROLOG to implement generate_fib(N,T) where T
represents the Nth term of the fibonacci series.
generate_fib(0,1).
generate_fib(1,1).
generate_fib(N,T):- N1 is N-1,
generate_fib(N1,T1),
N2 is N-2,
generate_fib(N2,T2),
T is T1+T2.
gcd(M,0,M):-!.
gcd(M,N,D):-N > 0,
X is mod(M,N),
gcd(N,X,D).
Q6. Write a Prolog program to implement power (Num,Pow, Ans) : where
Num is raised to the power Pow to get Ans.
power(Num,1,Num).
power(Num,Pow1,Ans1),
Ans is Ans1*Num.
multi(N1,1,N1).
multi(N1,Temp,Ans1),
Ans is Ans1+N1.
Q8.Write a program in PROLOG to implement towerofhanoi (N) where N
represents the number of discs.
power(Num,1,Num).
power(Num,Pow1,Ans1),
Ans is Ans1*Num.
toh(N,Ans):- power(2,N,Ans1),
Ans is Ans1-1.
Q9.Consider a cyclic directed graph [edge (p, q), edge (q, r), edge (q, r),
edge (q, s), edge (s,t)] where edge (A,B) is a predicate indicating directed
edge in a graph from a node A to a node B. Write a program to check
whether there is a route from one node to another node.
edge(p,q).
edge(q,r).
edge(r,s).
edge(s,t).
path(X,Y) :- edge(X,Y).
path(X,Y) :- edge(X,Z),
path(Z,Y).
Q10.Write a Prolog program to implement memb(X, L): to check whether
X is a member of L or not.
memb(X, [X|Tail]).
conc([],L,L).
conc([X|M],N,[X|Q]):- conc(M,N,Q).
Q12. Write a Prolog program to implement reverse (L, R) where List L is
original and List R is reversed list.
reverse([H|T],R):- length(T,L),
L>0 ->(reverse(T,R1),R is H) ;
R is H.
palind([]):- write('palindrome').
palind([_]):- write('palindrome').
write('Not a palindrome').
Q14.Write a Prolog program to implement sumlist(L, S) so that S is the
sum of a given list L.
sumlist([],0).
sumlist([H|T],S):- sumlist(T,S1),
S is H+S1.
even_length([]).
even_length([_|T]):- odd_length(T).
odd_length([_]).
odd_length([_|T]):- even_length(T).
Q16.Write a Prolog program to implement nth_element (N, L, X) where N
is the desired position, L is a list and X represents the Nth element of L.
nth_element(1,[H|T],H).
nth_element(N,[H|T],X):- N1 is N-1,
nth_element(N1,T,X).
is_member(X, [X|_]).
remove_dups([], []).
remove_dups(T, R).
remove_dups(T, R).
Q18.Write a Prolog program to implement maxlist(L, M) so that M is the
maximum number in the list.
maxlist([H],H).
maxlist([H|T],M):- maxlist(T,M1),
M is H.
insert(L,1,Elem,[Elem|L]):-!.
insert([],_,Elem,[Elem]).
insert([H|T],N,Elem,[H|R]):- C is N-1,
insert(T,C,Elem,R).
Q20.Write a Program in PROLOG to implement sublist(S, L) that checks
whether the list S is the sublist of list L or not.
sublist([],L).
sublist(S,[]):- false.
sublist([H1|T1],[H1|T2]):- sublist(T1,T2).
sublist([H1|T1],[H2|T2]):- sublist([H1|T1],T2).
delte(1,[_|T],T).
delte(P,[X|Y],[X|R]):-
P1 is P-1, delte(P1,Y,R).
Q22.Write a program in PROLOG to implement delete_all (X, L, R) where
X denotes the element whose all occurrences has to be deleted from list
`L to obtain list R.
dmerge([],L2,L2).
dmerge(L1,[],L1).
dmerge([H1|T1],[H2|T2],[H1|T3]):- H1=<H2,
sentence(A,C):-nounphrase(A,B),verbphrase(B,C).
nounphrase(A,C):-article(A,B),noun(B,C).
nounphrase(A,B):-noun(A,B).
verbphrase(A,B):-verb(A,B).
verbphrase(A,C):-verb(A,B),nounphrase(B,C).
verbphrase(A,C):-verb(A,B),prepositionphrase(B,C).
prepositionphrase(A,C):-proposition(A,B),nounphrase(B,C).
preposition([at|X],X).
article([the|X],X).
article([a|X],X).
noun([dog|X],X).
noun([cow|X],X).
noun([moon|X],X).
verb([barked|X],X).
verb([winked|X],X).