Advertisement
Guest User

Untitled

a guest
Jul 1st, 2019
119
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Prolog 3.84 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. /*
  70. fatorial(N,R) :-
  71.     N > 0,
  72.     N1 is N-1,
  73.     fatorial(N1,R1),
  74.     R is N*R1.
  75. */
  76.  
  77.  
  78.  
  79. /*grafos*/
  80. /*achando rotas*/
  81. ligado(a,b,5).
  82. ligado(b,c,10).
  83.  
  84. rota(X,Y,C) :- ligado(X,Y,C).
  85.  
  86. rota(X,Y,C) :-
  87.     ligado(X,Z,C1),
  88.     rota(Z,Y,C2),
  89.     C is (C1 + C2).
  90.  
  91.  
  92.  
  93.  
  94.  
  95.  
  96. /*listas*/
  97. max([X],X).
  98. max([X,Y|Cauda],Max) :- X >= Y, !, max([X|Cauda],Max).
  99. max([_,Y|Cauda],Max) :- max([Y|Cauda],Max). /*para o caso de X<Y*/
  100.  
  101. /*ou
  102.  
  103. max([X],X).
  104. max([X,Y|Cauda],Max) :- max(Cauda,G), X >= G, Max is X.
  105. max([X,Y|Cauda],Max) :- max(Cauda,G), X < G, Max is G.
  106. */
  107.  
  108. /*retirar uma ocorrencia de um elemento de uma lista*/
  109. retirar_elem(E,[E|L],L).
  110. retirar_elem(E,[E1|L],[E1|L1]) :- retirar_elem(E,L,L1).
  111.  
  112. %retirar todas as ocorrencias de um elemento de uma lista
  113. %warning singleton variables: [Elem] ocorre quando a variável "Elem" é "inútil" (poderia ser substituida por "_")
  114. retirar_todas(_,[],[]).
  115. retirar_todas(Elem,[Elem|Cauda],L) :-
  116.     retirar_todas(Elem,Cauda,L).
  117.  
  118.  
  119.  
  120.  
  121. /*EXERCÍCIOS*/
  122. %2
  123. separa([],[],[]).
  124. separa([X|Cauda],[X|P],N) :- X >= 0, separa(Cauda,P,N).
  125. separa([X|Cauda],P,[X|N]) :- X < 0, separa(Cauda,P,N).
  126.  
  127. %3
  128. segundo([_, X|_], X).
  129.  
  130. %4
  131. % iguais(X, X). %já funciona, mas para treinar a lógica é melhor a forma que foi feita.
  132. iguais([], []).
  133. iguais([X|Cauda1],[X|Cauda2]) :- iguais(Cauda1, Cauda2).
  134.  
  135. %5
  136. duplica([],[]).
  137. duplica([X|Cauda], [X,X|Y]) :- duplica(Cauda, Y).
  138.  
  139. %6
  140. ultimo([X], X).
  141. ultimo([_|Cauda], X) :- ultimo(Cauda, X).
  142.  
  143. %7
  144. soma([X], X).
  145. soma([X|Cauda], R) :- soma(Cauda, Y), R is X + Y.
  146.  
  147. %8
  148. fatorial(0, 1) :- !.
  149. fatorial(N, F) :- N > 0, M is N - 1, fatorial(M, F1), F is F1*N.
  150.  
  151. %9
  152. contiguo([X,X|_]) :- !.
  153. contiguo([_|Cauda]) :- contiguo(Cauda).
  154.  
  155. %10
  156. particiona([], [], []).
  157. particiona([X], [X|L1], L2) :- particiona([], L1, L2).
  158. particiona([X,Y|Cauda], [X|L1], [Y|L2]) :- particiona(Cauda, L1, L2).
  159.  
  160. %11
  161. mdc(A,0,A) :- !.
  162. mdc(A, B, C) :- R is A mod B, mdc(B, R, C).
  163.  
  164.  
  165. %21
  166. % Alunos
  167. aluno(joao, calculo).
  168. aluno(maria, calculo).
  169. aluno(joel, programacao).
  170. aluno(joel, estrutura).
  171.  
  172. % Estuda na...
  173. frequenta(joao, puc).
  174. frequenta(maria, puc).
  175. frequenta(joel, ufrj).
  176.  
  177. % Professors
  178. professor(carlos, calculo).
  179. professor(ana_paula, estrutura).
  180. professor(pedro, programacao).
  181.  
  182. % Funcionarios
  183. funcionario(pedro, ufrj).
  184. funcionario(ana_paula, puc).
  185. funcionario(carlos, puc).
  186.  
  187. % Quem são os alunos do professor X?
  188. prof(X,R) :- professor(X,D), findall(Y, aluno(Y,D), R).
  189.  
  190. % Quem são as pessoas que estão associadas a uma universidade X? (alunos e professores)
  191. universidade(X,Y) :- funcionario(Y,X); frequenta(Y,X).
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement