Listas em Prolog. Listas
|
|
|
- João Lucas Delgado Miranda
- 9 Há anos
- Visualizações:
Transcrição
1 Listas em Prolog Esta aula trata da estrutura de dados lista e programas Prolog para processamento de listas Inteligência Artificial 1 Listas Lista é uma das estruturas mais simples em Prolog, muito comum em programação não numérica Ela é uma seqüência ordenada de elementos Uma lista pode ter qualquer comprimento Por exemplo uma lista de elementos tais como ana, tênis, pedro pode ser escrita em Prolog como: [ana, tênis, pedro] 2 1
2 Listas O uso de colchetes é apenas uma melhoria da notação, pois internamente listas são representadas como árvores, assim como todos os objetos estruturados em Prolog Para entender a representação Prolog de listas, é necessário considerar dois casos A lista é vazia, escrita como [ ] em Prolog Uma lista (não vazia) consiste: no primeiro item, chamado cabeça (head) da lista na parte restante da lista, chamada cauda (tail) 3 Listas No exemplo [ana, tênis, pedro] ana é a Cabeça da lista [tênis, pedro] é a Cauda da lista A cabeça de uma lista pode ser qualquer objeto (inclusive uma lista); a cauda tem que ser uma lista A Cabeça e a Cauda são então combinadas em uma estrutura pelo functor especial..(cabeça, Cauda) Como a Cauda é uma lista, ela é vazia ou ela tem sua própria cabeça e sua cauda 4 2
3 Listas Assim, para representar listas de qualquer comprimento, nenhum princípio adicional é necessário O exemplo [ana, tênis, pedro] é representando como o termo:.(ana,.(tênis,.(pedro, []) ) ) ana.. O programador pode escolher ambas notações tênis. pedro [ ] 5 Listas?- Lista1 = [a,b,c], Lista2 =.(a,.(b,.(c,[]))). Lista1 = [a, b, c] Lista2 = [a, b, c]?- Hobbies1 =.(tênis,.(música,[])), Hobbies2 = [esqui, comida], L = [ana,hobbies1,pedro,hobbies2]. Hobbies1 = [tênis,música] Hobbies2 = [esqui,comida] L = [ana, [tênis,música], pedro, [esqui,comida]] 6 3
4 Listas Em geral, é comum tratar a cauda como um objeto simples Por exemplo, L = [a,b,c] pode ser escrito como Cauda = [b,c] L =.(a,cauda) Para expressar isso, Prolog fornece uma notação alternativa, a barra vertical, que separa a cabeça da cauda L = [a Cauda] A notação é geral por permitir que qualquer número de elementos seja seguido por e o restante da lista: [a,b,c] = [a [b,c]] = [a,b [c]] = [a,b,c [ ]] 7 Cabeça e Cauda - Exemplo 1 [maria, vicente, julia, yolanda] Cabeça: Cauda: 8 4
5 Cabeça e Cauda - Exemplo 1 [maria, vicente, julia, yolanda] Cabeça: Cauda: maria 9 Cabeça e Cauda - Exemplo 1 [maria, vicente, julia, yolanda] Cabeça: Cauda: maria [vicente, julia, yolanda] 10 5
6 Cabeça e Cauda - Exemplo 2 [[ ], dead(z), [2, [b,c]], [ ], Z, [2, [b,c]]] Cabeça: Cauda: 11 Cabeça e Cauda - Exemplo 2 [[ ], dead(z), [2, [b,c]], [ ], Z, [2, [b,c]]] Cabeça: [ ] Cauda: 12 6
7 Cabeça e Cauda - Exemplo 2 [[ ], dead(z), [2, [b,c]], [ ], Z, [2, [b,c]]] Cabeça: [ ] Cauda: [dead(z), [2, [b,c]], [ ], Z, [2, [b,c]]] 13 Cabeça e Cauda - Exemplo 3 [dead(z)] Cabeça: Cauda: 14 7
8 Cabeça e Cauda - Exemplo 3 [dead(z)] Cabeça: dead(z) Cauda: 15 Cabeça e Cauda - Exemplo 3 [dead(z)] Cabeça: dead(z) Cauda: [ ] 16 8
9 O operador built-in Prolog tem um built-in operador especial o qual pode ser usado para decompor uma lista em sua Cabeça e Cauda 17 O operador built-in?- [Cabeça Cauda] = [maria, vicente, julia, yolanda]. Cabeça = maria Cauda = [vicente,julia,yolanda] yes?- 18 9
10 O operador built-in?- [X Y] = [maria, vicente, julia, yolanda]. X = maria Y = [vicente,julia,yolanda] yes?- 19 O operador built-in?- [X Y] = [ ]. no?
11 O operador built-in?- [X,Y Cauda] = [[ ], dead(z), [2, [b,c]], [], [2, [b,c]]]. X = [ ] Y = dead(z) Cauda = [[2, [b,c]], [ ], [2, [b,c]]] yes?- 21 Unificação em Listas Lista1 Lista2 Lista1 = Lista2 [mesa] [X Y] X=mesa Y=[ ] [a,b,c,d] [X,Y Z] X=a Y=b Z=[c,d] [[ana,y] Z] [[X,foi],[ao,cinema]] X=ana Y=foi Z=[[ao,cinema]] [ano,bissexto] [X,Y Z] X=ano Y=bissexto Z=[ ] [ano,bissexto] [X,Y,Z] Não unifica 22 11
12 Variável Anônima Suponha que estamos interessados no segundo e quarto elemento de uma lista?- [X1,X2,X3,X4 Calda] = [maria, vicente, marcelo, josy, yolanda]. X1 = maria X2 = vicente X3 = marcelo X4 = josy Cauda = [yolanda] yes?- 23 Variável Anônima Há uma maneira mais simples de obter somente a informação que queremos:?- [ _,X2, _,X4 _ ] = [maria, vicente, marcelo, josy, yolanda]. X2 = vicente X4 = josy yes?
13 Operações em Listas Freqüentemente, é necessário realizar operações em listas, por exemplo, buscar um elemento que faz parte de uma lista Para isso, a recursão é o recurso mais amplamente empregado Questão: como verificar se um elemento está em uma lista? 25 Operações em Listas Freqüentemente, é necessário realizar operações em listas, por exemplo, buscar um elemento que faz parte de uma lista Para isso, a recursão é o recurso mais amplamente empregado Para verificar se um elemento está na lista, é preciso verificar se ele está na cabeça ou se ele está na cauda da lista Se o final da lista for atingido, o elemento não está na 26 lista 13
14 Predicado de Pertinência Inicialmente, é necessário definir o nome do predicado que verifica se um elemento pertence ou não a uma lista, por exemplo, pertence(x,y) A primeira condição especifica que um elemento X pertence à lista se ele está na cabeça dela. Isso é indicado como: pertence(x,[x Z]). A segunda condição especifica que um elemento X pertence à lista se ele pertencer à sua cauda. Isso pode ser indicado como: pertence(x,[w Z]) :- pertence(x,z). 27 Predicado de Pertinência Sempre que um procedimento recursivo é definido, deve-se procurar pelas condições limites (ou condições de parada) e pelo caso recursivo: pertence(cabeca, [Cabeca Cauda]). pertence(cabeca, [OutraCabeca Cauda]) :- pertence(cabeca,cauda). Após a definição do procedimento pertence/2, é possível interrogá-lo.?- pertence(a,[a,b,c]). yes 28 14
15 Predicado de Pertinência?- pertence(d,[a,b,c]). no?- pertence(x,[a,b,c]). X = a ; X = b ; X = c ; no Entretanto, se as interrogações forem:?- pertence(a,x).?- pertence(x,y). deve-se observar que cada uma delas tem infinitas respostas, pois existem infinitas listas que validam essas interrogações para o procedimento pertence/2 29 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?
16 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(yolanda,[yolanda,tadeu,vicente,julia]). 31 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(yolanda,[yolanda,tadeu,vicente,julia]). yes?
17 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(vicente,[yolanda,tadeu,vicente,julia]). 33 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(vicente,[yolanda,tadeu,vicente,julia]). yes?
18 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(zeus,[yolanda,tadeu,vicente,julia]). 35 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(zeus,[yolanda,tadeu,vicente,julia]). no?
19 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(x,[yolanda,tadeu,vicente,julia]). 37 Exemplo pertence/2 pertence(x,[x T]). pertence(x,[h T]):- pertence(x,t).?- pertence(x,[yolanda,tadeu,vicente,julia]). X = yolanda; X = tadeu; X = vicente; X = julia; no 38 19
20 Modos de Ativação de Procedimentos Para documentar as possíveis instanciações de variáveis para as quais o procedimento é correto, utiliza-se a seguinte notação (como comentário no programa): + o argumento é de entrada (deve estar instanciado) o argumento é de saída (não deve estar instanciado)? o argumento é de entrada e saída (pode ou não estar instanciado) O procedimento pertence/2 documentado com o modo de chamada para atingir a condição de parada é: % pertence(?elemento, +Lista) pertence(e, [E _]). pertence(e, [_ Cauda]) :- pertence(e,cauda). 39 Exercício Inserção de um elemento na primeira posição de uma lista 40 20
21 Exemplo: Inserção Inserção na primeira posição: insere(x, L, [X L]).?- insere(a, [b,c,d], Y). Y=[a,b,c,d]; no X = a L = [b, c, d] Y = [X L] = [a, b, c, d] 41 Exercício Converter valores de uma lista em seus valores absolutos 42 21
22 Exemplo: Converte Converte valores de uma lista em seus valores absolutos. Exemplo:?- converte([5,-3, 1, -4], L). L= [5, 3, 1, 4] converte([ ], [ ]). converte([x L1], [Y L2]):- abs(x,y), converte(l1, L2). 43 converte/2 (arvore de busca)?- converte([-4], R). R = [4 L0]?- converte([ ],L0) / converte([ ], [ ]). converte([x L1], [Y L2]):- abs(x,y), converte(l1, L2). L0=[ ] L0=[ ] R=[4 L0]=[4] 44 22
23 converte/2 (arvore de busca)?- converte([-4, -3], R). R = [4 L0]?- converte([-3], L0) L0=[3 L1]?- converte([], L1) / L1=[] converte([ ], [ ]). converte([x L1], [Y L2]):- abs(x,y), converte(l1, L2). L1=[ ] L0=[3 L1]=[3] R=[4 L0]=[4,3] 45 Exercício Definir o procedimento último(elem,lista) que encontra o último elemento Elem de uma lista Lista Qual a lógica? 46 23
24 Exercício Definir o procedimento último(elem,lista) que encontra o último elemento Elem de uma lista Lista O último elemento de uma lista que tem somente um elemento é o próprio elemento O último elemento de uma lista que tem mais de um elemento é o ultimo elemento da cauda 47 Último Elemento de uma Lista O último elemento de uma lista que tem somente um elemento é o próprio elemento ultimo(elemento, [Elemento]). O último elemento de uma lista que tem mais de um elemento é o ultimo elemento da cauda ultimo(elemento, [Cabeca Cauda]) :- ultimo(elemento,cauda). Procedimento completo: % ultimo(?elemento, +Lista) ultimo(elemento, [Elemento]). ultimo(elemento, [Cabeca Cauda]) :- ultimo(elemento,cauda)
25 Exercício Concatenar duas listas, formando uma terceira Qual a lógica? 49 Exercício Concatenar duas listas, formando uma terceira Se o primeiro argumento é a lista vazia, então o segundo e terceiro argumentos devem ser o mesmo Se o primeiro argumento é a lista não-vazia, então ela tem uma cabeça e uma cauda da forma [X L1]; concatenar [X L1] com uma segunda lista L2 resulta na lista [X L3], onde L3 é a concatenação de L1 e L
26 Concatenar duas Listas Se o primeiro argumento é a lista vazia, então o segundo e terceiro argumentos devem ser o mesmo concatenar([ ],L,L). Se o primeiro argumento é a lista não-vazia, então ela tem uma cabeça e uma cauda da forma [X L1]; concatenar [X L1] com uma segunda lista L2 resulta na lista [X L3], onde L3 é a concatenação de L1 e L2 concatenar([x L1],L2,[X L3]) :- [X L1] concatenar(l1,l2,l3). Procedimento completo: % concatenar(?/+l1,?/?l2,+/?l) concatenar([ ],L,L). L3 concatenar([x L1],L2,[X L3]) :- X L3 concatenar(l1,l2,l3). X L1 L2 [X L3] 51 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3)
27 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3). 53 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3)
28 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3). 55 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) L0=[b L1]?- concatenar([c],[1,2,3],l1) concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3)
29 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) L0=[b L1]?- concatenar([c],[1,2,3],l1) concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3). 57 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) L0=[b L1]?- concatenar([c],[1,2,3],l1) concatenar([], L, L). concatenar([x L1], L2, [X L3]):- L1=[c L2]?- concatenar([],[1,2,3],l2) concatenar(l1, L2, L3)
30 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) L0=[b L1]?- concatenar([c],[1,2,3],l1) L1=[c L2] concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3).?- concatenar([],[1,2,3],l2) 59 concatenar/3 (arvore de busca)?- concatenar([a,b,c],[1,2,3], R). R = [a L0]?- concatenar([b,c],[1,2,3],l0) L0=[b L1]?- concatenar([c],[1,2,3],l1) L1=[c L2] concatenar([], L, L). concatenar([x L1], L2, [X L3]):- concatenar(l1, L2, L3).?- concatenar([],[1,2,3],l2) L2=[1,2,3] 60 30
31 concatenar/3 (arvore de busca) concatenar([], L, L).?- concatenar([a,b,c],[1,2,3], R). concatenar([x L1], L2, [X L3]):- R = [a L0]?- concatenar([b,c],[1,2,3],l0) concatenar(l1, L2, L3). L0=[b L1]?- concatenar([c],[1,2,3],l1) L2=[1,2,3] L1=[c L2] L1=[c L2]=[c,1,2,3]?- concatenar([],[1,2,3],l2) L0=[b L1]=[b,c,1,2,3] R=[a L0]=[a,b,c,1,2,3] L2=[1,2,3] 61 Exemplo concatenar/3 concatenar([], L, L). concatenar([x L], L2, [X L3]):- concatenar(l, L2, L3).?- concatenar(x, Y, [1,2,3,4]). X = [ ] Y = [1,2,3,4]; X = [1] Y = [2,3,4]; X = [1,2] Y = [3,4]; X = [1,2,3] Y = [4]; X = [1,2,3,4] Y = [ ]; no 62 31
32 Exercícios Encontrar o maior valor de uma lista de valores numéricos. 63 Exercícios Verificar se dois elementos são consecutivos em uma lista
33 Exercícios Somar elementos de uma lista numérica. 65 Exercícios Encontrar n-ésimo elemento de uma lista
34 Exercícios Determinar o número de elementos de uma lista. 67 Exercícios Retirar uma ocorrência de um elemento de uma lista
35 Exercícios Substituir elemento de uma lista por um outro elemento. 69 Exercícios Dividir uma lista numérica em 2 sublistas que contenham os elementos iguais ou menores e os maiores que um dado elemento
Sintaxe e Semântica de Programas Prolog
Sintaxe e Semântica de Programas Prolog Esta aula trata da sintaxe e semântica de conceitos básicos em Prolog relacionados à manipulação de listas Lista é uma das estruturas mais simples em Prolog, muito
Sintaxe e Semântica de Programas Prolog
Inteligência Artificial Sintaxe e Semântica de Programas Prolog José Augusto Baranauskas Departamento de Física e Matemática FFCLRP-USP Nesta aula será vista a sintaxe e semântica de conceitos básicos
Prof. A. G. Silva. 24 de agosto de Prof. A. G. Silva Programação em Lógica 24 de agosto de / 1
Programação em Lógica Prof. A. G. Silva 24 de agosto de 2017 Prof. A. G. Silva Programação em Lógica 24 de agosto de 2017 1 / 1 Termos Referem-se a todas as construções sintáticas da linguagem Um termo
SCC Capítulo 5 Representação de Conhecimento através do Prolog
SCC-630 - Capítulo 5 Representação de Conhecimento através do Prolog João Luís Garcia Rosa 1 1 Departamento de Ciências de Computação Instituto de Ciências Matemáticas e de Computação Universidade de São
Linguagens de Programação Aula 14
Linguagens de Programação Aula 14 Celso Olivete Júnior [email protected] Na aula passada Linguagem Haskell Funções Tipos básicos Expressões 2 Na aula de hoje Linguagem Haskell Listas 3 Listas e Tuplas
Listas em Haskell. Listas. Linguagem Haskell. Maria Adriana Vidigal de Lima. Faculdade de Computação - UFU. Setembro
em Haskell Linguagem Haskell Faculdade de Computação - UFU Setembro - 2009 em Haskell 1 em Haskell Noções sobre Construção de por Compreensão Funções Sobre Processamento de Fundamentos em Haskell Noções
03/04/2016 LÓGICA MATEMÁTICA. Prof. Esp. Fabiano Taguchi. Introdução ao Prolog
LÓGICA MATEMÁTICA Prof. Esp. Fabiano Taguchi [email protected] http://fabianotaguchi.wordpress.com Introdução ao Prolog 1 PROLOG PROgramming in LOGic Linguagem utilizada para resolver problemas
Paradigmas de Programação
Paradigmas de Programação Fabrício Olivetti de França 21 de Junho de 2018 1 Listas 2 Listas Uma das principais estruturas em linguagens funcionais. Representa uma coleção de valores de um determinado tipo.
Listas: nós de cabeçalho, listas não homogêneas, listas generalizadas
Listas: nós de cabeçalho, listas não homogêneas, listas generalizadas SCC-502 Algoritmos e Estruturas de Dados I Prof. Thiago A. S. Pardo Lista com nó de cabeçalho Nó de cabeçalho Header, sentinela, etc.
Recursão PROGRAMAÇÃO EM LÓGICA. Recursão. Sonho Recursivo. Recursão. Recursão. Linguagem Prolog Parte IV
PROGRAMAÇÃO EM LÓGICA Recursão CIÊNCIA DA COMPUTAÇÃO FACAPE Faculdade de Ciências Aplicadas e Sociais de Petrolina Linguagem Prolog Parte IV Usado desde a arte (em figuras, telas, etc) como também em Matemática
Programação Funcional
Programação Funcional Lucília Camarão de Figueiredo Universidade Federal de Ouro Preto [email protected] Aula 07: Funções de Ordem Superior 1 INTRODUÇÃO Uma função é chamada função de ordem superior
Listas: nós de cabeçalho, listas não homogêneas, listas generalizadas. SCC-502 Algoritmos e Estruturas de Dados I
Listas: nós de cabeçalho, listas não homogêneas, listas generalizadas SCC-502 Algoritmos e Estruturas de Dados I Lista com nó de cabeçalho Nó de cabeçalho Header, sentinela, etc. Para que? Sentinela Beth
Aulas 10 e 11 / 18 e 20 de abril
1 Conjuntos Aulas 10 e 11 / 18 e 20 de abril Um conjunto é uma coleção de objetos. Estes objetos são chamados de elementos do conjunto. A única restrição é que em geral um mesmo elemento não pode contar
Listas generalizadas. SCC-202 Algoritmos e Estruturas de Dados I
Listas generalizadas SCC-202 Algoritmos e Estruturas de Dados I Lista generalizada Uma lista generalizada é aquela que pode ter como elemento ou um átomo ou uma outra lista (sub-lista) Átomo: integer,
Linguagens Formais e Problemas de Decisão
Linguagens Formais e Problemas de Decisão Mário S. Alvim ([email protected]) Fundamentos de Teoria da Computação (FTC) DCC-UFMG (2018/02) Mário S. Alvim ([email protected]) Linguagens Formais e Problemas
6. OPERADORES E ARITMÉTICA
6. OPERADORES E ARITMÉTICA 6.1 OPERADORES Na matemática costuma-se escrever expressões como 2*a + b*c onde + e * são operadores e 2, a, b e c são argumentos. Em particular, + e * são denominados operadores
Algoritmos e Estrutura de Dados Aula 08 Pilhas
Algoritmos e Estrutura de Dados Aula 08 Pilhas Profa. Alana Oliveira e Prof. Davi Viana [email protected] e [email protected] Se não entender, pergunte! Dados e Tipos de Dados Um dado é uma informação
Pedro Vasconcelos DCC/FCUP. Programação Funcional 4 a Aula Listas
Programação Funcional 4 a Aula Listas Pedro Vasconcelos DCC/FCUP 2014 Listas Listas são coleções de elementos: em que a ordem é significativa; possivelmente com elementos repetidos. Listas em Haskell Uma
Descrição do Mundo de Wumpus. Inteligência Artificial
Descrição do Mundo de Wumpus Mundo de Wumpus Mundo de Wumpus -1 Mundo de Wumpus - 2 Mundo de Wumpus - 3 Mundo de Wumpus - 4 Wumpus Outros Pontos Críticos Descrição Lógica do Mundo de Wumpus Identidades
USANDO UM MÉTODO INDUTIVO PARA RESOLVER PROBLEMAS. Bruno Maffeo Departamento de Informática PUC-Rio
USANDO UM MÉTODO INDUTIVO PARA RESOLVER PROBLEMAS Bruno Maffeo Departamento de Informática PUC-Rio MÉTODO INDUTIVO O método indutivo para resolver problemas aqui empregado inspira-se na formulação mais
Linguagens e Autômatos
167657 - Controle para Automação Curso de Graduação em Engenharia de Controle e Automação Departamento de Engenharia Elétrica Universidade de Brasília Linguagens e Autômatos Geovany A. Borges [email protected]
Linguagens Formais e Autômatos 02/2015. LFA Aula 02. introdução 28/09/2015. Celso Olivete Júnior.
LFA Aula 02 Linguagens regulares - introdução 28/09/2015 Celso Olivete Júnior [email protected] 1 Na aula passada... Visão geral Linguagens regulares expressões regulares autômatos finitos gramáticas
Introdução à Programação em Prolog
Introdução à Programação em Prolog Thiago A. S. Pardo Solange Rezende Exercício em duplas Introdução (1 de 4) Escrever um programa completo em C que armazene quem gosta de quem e que responda sim ou não
Alguns Exercícios de Inteligência Artificial
Alguns Exercícios de Inteligência Artificial Ana Paula Tomás Nelma Moreira Departamento de Ciência de Computadores Faculdade de Ciências, Universidade do Porto email: {apt,nam}@ncc.up.pt 1997 1. Números
IBM1088 Linguagens Formais e Teoria da
IBM1088 Linguagens Formais e Teoria da Computação Linguagens e Gramáticas Evandro Eduardo Seron Ruiz [email protected] Universidade de São Paulo E.E.S. Ruiz (USP) LFA 1 / 47 Frase do dia Sofremos muito com
Notas de aula: Cálculo e Matemática Aplicados às Notas de aula: Ciências dos Alimentos
Notas de aula: Cálculo e Matemática Aplicados às Notas de aula: Ciências dos Alimentos 1 Conjuntos Um conjunto está bem caracterizado quando podemos estabelecer com certeza se um elemento pertence ou não
Capítulo 1: Alfabetos, cadeias, linguagens
Capítulo 1: Alfabetos, cadeias, linguagens Símbolos e alfabetos. Um alfabeto é, para os nossos fins, um conjunto finito não vazio cujos elementos são chamados de símbolos. Dessa maneira, os conceitos de
Linguagens Não-Regulares
Linguagens Não-Regulares Mário S. Alvim ([email protected]) Fundamentos de Teoria da Computação (FTC) DCC-UFMG (2018/02) Mário S. Alvim ([email protected]) Linguagens Não-Regulares DCC-UFMG (2018/02)
INE5403 FUNDAMENTOS DE MATEMÁTICA DISCRETA
INE5403 FUNDAMENTOS DE MATEMÁTICA DISCRETA PARA A COMPUTAÇÃO PROF. DANIEL S. FREITAS UFSC - CTC - INE Prof. Daniel S. Freitas - UFSC/CTC/INE/2007 p.1/30 3 - INDUÇÃO E RECURSÃO 3.1) Indução Matemática 3.2)
LFA. Aula 04. Sintaxe e Semântica. Conceitos Básicos Alfabeto Palavra Linguagem
LFA Aula 04 Sintaxe e Semântica. Conceitos Básicos Alfabeto Palavra Linguagem Linguagens Formais Linguagens formais se preocupam com os problemas sintáticos das linguagens. Sintaxe e Semântica Sintaxe
Já falamos que, na Matemática, tudo se baseia em axiomas. Já estudamos os números inteiros partindo dos seus axiomas.
Teoria dos Conjuntos Já falamos que, na Matemática, tudo se baseia em axiomas. Já estudamos os números inteiros partindo dos seus axiomas. Porém, não é nosso objetivo ver uma teoria axiomática dos conjuntos.
Recursividade e listas
Recursividade e listas Prof. Dr. Silvio do Lago Pereira Departamento de Tecnologia da Informação Faculdade de Tecnologia de São Paulo Princípio de recursividade Recursividade é um princípio que permite
LINGUAGEM LIVRE DE CONTEXTO GRAMÁTICA LIVRE DE CONTEXTO
LINGUAGEM LIVRE DE CONTEXTO As Linguagens Livres de Contexto é um reconhecedor de linguagens, capaz de aceitar palavras corretas (cadeia, sentenças) da linguagem. Por exemplo, os autômatos. Um gerador
Alfabeto, Cadeias, Operações e Linguagens
Linguagens de Programação e Compiladores - Aula 3 1 Alfabeto, Cadeias, Operações e Linguagens 1.Conjuntos Para representar um determinado conjunto é necessário buscar uma notação para representá-lo e ter
Inteligência Artificial. Prolog. Aula 2 Introdução (cont.)
Universidade Estadual do Oeste do Paraná Curso de Bacharelado em Ciência da Computação http://www.inf.unioeste.br/~claudia/ia2017.html Inteligência Artificial Prolog Aula 2 Introdução (cont.) Características
Conceitos Básicos. Vocabulário Cadeias Linguagens Problema
Conceitos Básicos Vocabulário Cadeias Linguagens Problema Alfabeto ou Vocabulário: Conjunto finito não vazio de símbolos. Símbolo é um elemento qualquer de um alfabeto. Ex: {A,B,C,.Z} alfabeto latino (maiúsculas)
Pedro Vasconcelos DCC/FCUP. Programação Funcional 3 a Aula Definição de funções
Programação Funcional 3 a Aula Definição de funções Pedro Vasconcelos DCC/FCUP 2014 Definição de funções Podemos definir novas funções simples usando funções pré-definidas. minuscula :: Char -> Bool minuscula
Teoria da Computação
Introdução Março - 2009 1 Noções e Terminologia Matemática Conjuntos Um conjunto é um grupo de objetos, chamados elementos ou membros, representado como uma unidade. O conjunto { 3, 41, 57} possui os elementos
Textos de apoio às aulas práticas. Jaime Ramos, Francisco Miguel Dionísio
Computação e Programação Textos de apoio às aulas práticas Jaime Ramos, Francisco Miguel Dionísio DMIST, Dezembro de 2010 Parte I MATLAB 1 Capítulo 1 Exercícios preliminares 1. Defina a função conta divisores
Linguagem Haskell. Universidade Estadual Santa Cruz Conceitos de Linguagens de Programação. Tiago Carneiro 19 Agosto 2013
Linguagem Haskell Universidade Estadual Santa Cruz Conceitos de Linguagens de Programação Tiago Carneiro 19 Agosto 2013 1 1 Linguagem Haskell Linguagem de programação funcional É um paradigma de programação
Linguagem Haskell. Riocemar S. de Santana
Linguagem Haskell Riocemar S. de Santana Haskell, o que é? É uma linguagem de programação puramente funcional, de propósito geral. Nomeada em homenagem ao matemático americano Haskell B. Curry (1900 1982).
Linguagens de Programação Programação Lógica (Prolog)
Linguagens de Programação Programação Lógica (Prolog) Andrei Rimsa Álvares Sumário Introdução Prolog Unificação Mais sobre Prolog Resumo INTRODUÇÃO Linguagens de Programação Programação Impera?va vs. Lógica
Unidade I MATEMÁTICA. Prof. Celso Ribeiro Campos
Unidade I MATEMÁTICA Prof. Celso Ribeiro Campos Números reais Três noções básicas são consideradas primitivas, isto é, são aceitas sem a necessidade de definição. São elas: a) Conjunto. b) Elemento. c)
UNIDADE ACADÊMICA: Faculdade de
UNIVERSIDADE FEDERAL DE UBERLÂNDIA FACULDADE DE COMPUTAÇÃO BACHARELADO EM SISTEMAS DE INFORMAÇÃO PLANO DE DISCIPLINA DISCIPLINA: Programação Lógica ( X ) SEMESTRAL - ( ) ANUAL CÓDIGO: GSI010 PERÍODO: 2
Segunda Lista de Exercícios 2004/2...
+ + UFLA Universidade Federal de Lavras Departamento de Ciência da Computação COM162 Linguagens Formais e Autômatos Prof. Rudini Sampaio Monitor: Rodrigo Pereira dos Santos Segunda Lista de Exercícios
Fundamentos 1. Lógica de Predicados
Fundamentos 1 Lógica de Predicados Predicados e Quantificadores Estudamos até agora a lógica proposicional Predicados e Quantificadores Estudamos até agora a lógica proposicional A lógica proposicional
Programação Lógica. Controle (Bactracking, Cut, Fail) Paulo Henrique Ribeiro Gabriel
Programação Lógica Controle (Bactracking, Cut, Fail) Paulo Henrique Ribeiro Gabriel [email protected] Faculdade de Computação Universidade Federal de Uberlândia 7 de outubro de 2015 Paulo H. R. Gabriel (FACOM/UFU)
Objetos Estruturados Listas Recursão Exercícios. Inteligência Artificial
Prolog Objetos Estruturados Objetos Estruturados Listas Recursão Exercícios Inteligência Artificial Exercícios Relembrando a introdução: 1. Escreva um programa Prolog para representar: João nasceu em Campos
Pedro Vasconcelos DCC/FCUP. Programação Funcional 5 a Aula Definições recursivas
Programação Funcional 5 a Aula Definições recursivas Pedro Vasconcelos DCC/FCUP 2014 Definições usando outras funções Podemos definir funções usando outras previamente definidas (e.g. do prelúdio-padrão).
Capítulo 3 Lógica de Primeira Ordem
Capítulo 3 Lógica de Primeira Ordem Lógica para Programação LEIC - Tagus Park 1 o Semestre, Ano Lectivo 2007/08 c Inês Lynce and Luísa Coheur Bibliografia Baseados nos slides de Andrew Rice, Universidade
Conceitos de Linguagens de Programação
Conceitos de Linguagens de Programação Aula 09 Programação Funcional (Haskell) Edirlei Soares de Lima Programação Funcional A programação funcional modela um problema computacional
Introdução à Programação
Introdução à Programação Aula 10: Listas e tuplos Rita P. Ribeiro 2016/2017 Departamento de Ciência de Computadores Nesta aula 1. Listas 2. Tuplos INTRODUÇÃO À PROGRAMAÇÃO - 2016/2017: AULA 10 1 Listas
Pedro Vasconcelos DCC/FCUP. Programação Funcional 8 a Aula Listas infinitas
Programação Funcional 8 a Aula Listas infinitas Pedro Vasconcelos DCC/FCUP 2014 Listas infinitas Podemos usar listas para sequências finitas, por ex.: [1,2,3,4] = 1:2:3:4:[] Nesta aula vamos ver que podemos
Python: Listas. Claudio Esperança
Python: Listas Claudio Esperança Estruturas de dados Maneira de organizar dados de maneira a facilitar seu acesso Algumas formas são clássicas: Listas Arrays (vetores e matrizes) Tuplas (registros) Árvores
Exercícios: Recursão
Universidade Federal de Uberlândia - UFU Faculdade de Computação - FACOM Lista de exercícios de programação em linguagem C Exercícios: Recursão 1. Faça uma função recursiva que calcule e retorne o fatorial
Lista de Exercício de Linguagens de Programação Prog. Funcional
UNIVERSIDADE FEDERAL FLUMINENSE INSTITUTO DE CIÊNCIA E TECNOLOGIA CURSO DE CIÊNCIA DA COMPUTAÇÃO Lista de Exercício de Linguagens de Programação Prog. Funcional 1) Construa uma função del_posicao_n ::
Pedro Vasconcelos DCC/FCUP. Programação Funcional 2 a Aula Tipos e classes
Programação Funcional 2 a Aula Tipos e classes Pedro Vasconcelos DCC/FCUP 2012 Tipos Um tipo é um nome para uma coleção de valores relacionados. Por exemplo, o tipo Bool True contém dois valores lógicos:
AULA TEÓRICA RESOLUÇÃO DE PROBLEMAS 4ª
AULA TEÓRICA RESOLUÇÃO DE PROBLEMAS 4ª Aula por Helder Coelho IIA 1 REPRESENTAÇÃO E INTELIGÊNCIA QUESTÕES PARA DISCUSSÃO: Transformação do problema compreender o problema reflectir/pensar o problema lógica,
Pedro Vasconcelos DCC/FCUP. Programação Funcional 13 a Aula Definição de tipos
Programação Funcional 13 a Aula Definição de tipos Pedro Vasconcelos DCC/FCUP 2014 Declarações de sinónimos Podemos dar um nome novo a um tipo existente usando uma declaração de sinónimo. Exemplo (do prelúdio-padrão):
EXERCÍCIOS DE PROGRAMAÇÃO EM LÓGICA
FACULDADE DE ENGENHARIA DA UNIVERSIDADE DO PORTO EXERCÍCIOS DE PROGRAMAÇÃO EM LÓGICA LUÍS PAULO REIS DANIEL CASTRO SILVA MESTRADO INTEGRADO EM ENGENHARIA INFORMÁTICA E COMPUTAÇÃO PROGRAMAÇÃO EM LÓGICA
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Linguagens Formais e Autômatos - P. Blauth Menezes 1 Linguagens
PARECER DOS RECURSOS
Associação Catarinense das Fundações Educacionais ACAFE PROCESSO SELETIVO ADMISSÃO DE PROFESSORES EM CARÁTER TEMPORÁRIO EDITAL Nº 15/ 2012/ SED PARECER DOS RECURSOS CARGO: Professor de Matemática 11) São
Lista 02: Pilhas & Filas
MAC122 Princípios de Desenvolvimento de Algoritmos DCC IME USP 2º Semestre de 2018 Prof.: Dr. Paulo Miranda [email protected] Lista 02: Pilhas & Filas Para as questões envolvendo pilhas, assuma
Símbolo Nome lê-se como Categoria = 10 significa que se se somar 4 a 6, a soma, ou resultado, é 10.
Símbolo Nome lê-se como Categoria adição mais aritmética + 4 + 6 = 10 significa que se se somar 4 a 6, a soma, ou resultado, é 10. Exemplo: 43 + 65 = 108; 2 + 7 = 9 subtração menos aritmética - 9-4 = 5
Programação Funcional Aulas 5 & 6
Programação Funcional Aulas 5 & 6 Sandra Alves DCC/FCUP 2016/17 Definições usando outras funções Podemos definir funções usando outras previamente definidas (por exemplo: do prelúdio-padrão). Exemplo:
Algoritmos e Lógica de Programação 80 horas // 4 h/semana. Exercício... Para começar... Resolução... Para começar... Para começar...
Algoritmos e Lógica de Programação 80 horas // 4 h/semana Estrutura Condicional: aninhada, seleção de casos e outras. Aula 06 Prof. Piva Exercício... Faça um algoritmo que leia dois números inteiros e
Conceitos Básicos. Vocabulário Cadeias Linguagens Expressões Regulares Problema X Linguagem
Conceitos Básicos Vocabulário Cadeias Linguagens Expressões Regulares Problema X Linguagem Alfabeto ou Vocabulário: Conjunto finito não vazio de símbolos. Símbolo é um elemento qualquer de um alfabeto.
Exercícios: Árvores. Universidade Federal de Uberlândia - UFU Faculdade de Computação - FACOM Lista de exercícios de estrutura de dados em linguagem C
Universidade Federal de Uberlândia - UFU Faculdade de Computação - FACOM Lista de exercícios de estrutura de dados em linguagem C Exercícios: Árvores 1. Utilizando os conceitos de grafos, defina uma árvore.
Aula 19 Conjuntos disjuntos (Union-find)
MC3305 Algoritmos e Estruturas de Dados II Aula 19 Conjuntos disjuntos (Union-find) Prof. Jesús P. Mena-Chalco [email protected] 2Q-2015 1 Números de Ackermann 2 3 Ackermann A função de Ackermann
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Linguagens Formais e Autômatos - P. Blauth Menezes 1 Linguagens
