Advertisement
Guest User

Untitled

a guest
Jun 24th, 2019
70
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Prolog 2.66 KB | None | 0 0
  1. /*NOTA: NUNCA DEIXAR COMENTÁRIO "GRUDADO NA HORIZOTAL" EM CÓDIGO*/
  2. % "codigo./*comentario*/" deu problema
  3. progenitor(hugo,hudson).
  4. progenitor(diva,hudson).
  5. progenitor(hugo,irmo).
  6. progenitor(diva,irmo).
  7. progenitor(hugo,irma).
  8. progenitor(diva,irma).
  9. progenitor(vop,hugo).
  10. progenitor(vohp,hugo).
  11. progenitor(vom,diva).
  12. progenitor(vohm,diva).
  13. progenitor(vop,tio).
  14. progenitor(vohp,tio).
  15. progenitor(vop,tia).
  16. progenitor(vohp,tia).
  17.  
  18. homem(hugo).
  19. homem(hudson).
  20. homem(irmo).
  21. homem(vop).
  22. homem(vom).
  23. homem(tio).
  24.  
  25. mulher(diva).
  26. mulher(irma).
  27. mulher(vohp).
  28. mulher(vohm).
  29. mulher(tia).
  30.  
  31.  
  32.  
  33. pai(X,Y) :- progenitor(X,Y), homem(X).
  34. mae(X,Y) :- progenitor(X,Y), mulher(X).
  35. filho(X,Y) :- progenitor(Y,X), homem(X).
  36. filha(X,Y) :- progenitor(Y,X), mulher(X).
  37. irmao(X,Y) :- progenitor(A,Y), progenitor(A,X), homem(X), X \== Y.
  38. irma(X,Y) :- progenitor(A,Y), progenitor(A,X), mulher(X), X \== Y.
  39. avo(X,Y) :- progenitor(X,A), progenitor(A,Y), homem(X).
  40. avoh(X,Y) :- progenitor(X,A), progenitor(A,Y), mulher(X).
  41. descendente(X,Y) :- progenitor(Y,X).
  42. descendente(X,Y) :- progenitor(Y,F), progenitor(F,X).
  43.  
  44.  
  45.  
  46.  
  47.  
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54. soma(X,X,X).
  55. soma(X,Y,S) :-
  56.     X < Y,
  57.     ProximoX is X+1,
  58.     soma(ProximoX, Y, PS),
  59.     S is PS+X.
  60. soma(X,Y,S) :- soma(Y,X,S).
  61.  
  62.  
  63.  
  64.  
  65. /*fatorial*/
  66.  
  67. fatorial(0,1).
  68.  
  69. fatorial(N,R) :-
  70.     N > 0,
  71.     N1 is N-1,
  72.     fatorial(N1,R1),
  73.     R is N*R1.
  74.  
  75.  
  76.  
  77.  
  78. /*grafos*/
  79. /*achando rotas*/
  80. ligado(a,b,5).
  81. ligado(b,c,10).
  82.  
  83. rota(X,Y,C) :- ligado(X,Y,C).
  84.  
  85. rota(X,Y,C) :-
  86.     ligado(X,Z,C1),
  87.     rota(Z,Y,C2),
  88.     C is (C1 + C2).
  89.  
  90.  
  91.  
  92.  
  93.  
  94.  
  95. /*listas*/
  96. max([X],X).
  97. max([X,Y|Cauda],Max) :- X >= Y, !, max([X|Cauda],Max).
  98. max([_,Y|Cauda],Max) :- max([Y|Cauda],Max). /*para o caso de X<Y*/
  99.  
  100. /*ou
  101.  
  102. max([X],X).
  103. max([X,Y|Cauda],Max) :- max(Cauda,G), X >= G, Max is X.
  104. max([X,Y|Cauda],Max) :- max(Cauda,G), X < G, Max is G.
  105. */
  106.  
  107. /*retirar uma ocorrencia de um elemento de uma lista*/
  108. retirar_elem(E,[E|L],L).
  109. retirar_elem(E,[E1|L],[E1|L1]) :- retirar_elem(E,L,L1).
  110.  
  111. %retirar todas as ocorrencias de um elemento de uma lista
  112. %warning singleton variables: [Elem] ocorre quando a variável "Elem" é "inútil" (poderia ser substituida por "_")
  113. retirar_todas(_,[],[]).
  114. retirar_todas(Elem,[Elem|Cauda],L) :-
  115.     retirar_todas(Elem,Cauda,L).
  116.  
  117.  
  118.  
  119.  
  120. /*EXERCÍCIOS*/
  121. %2
  122. separa([],[],[]).
  123. separa([X|Cauda],[X|P],N) :- X >= 0, separa(Cauda,P,N).
  124. separa([X|Cauda],P,[X|N]) :- X < 0, separa(Cauda,P,N).
  125.  
  126. %3
  127. segundo([_, X|_], X).
  128.  
  129. %4
  130. % iguais(X, X). %já funciona, mas para treinar a lógica é melhor a forma que foi feita.
  131. iguais([], []).
  132. iguais([X|Cauda1],[X|Cauda2]) :- iguais(Cauda1, Cauda2).
  133.  
  134. %5
  135. duplica([],[]).
  136. duplica([X|Cauda], [X,X|Y]) :- duplica(Cauda, Y).
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement