Inteligencia Artificial: Prolog
|
|
|
- María Rosa Salinas Herrero
- hace 9 años
- Vistas:
Transcripción
1 Inteligencia Artificial: Prolog Listas Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España)
2 Contenidos Qué es una lista? Operador El predicado member El predicado deleteall El predicado append Librería lists.pl 2 of 1
3 Qué es una lista? Una lista en Prolog es una estructura de datos que permite almacenar cualquier tipo de elemento definido en el lenguaje: constantes, variables y estructuras Las listas se definen encerrando sus elementos entre corchetes Los elementos de una lista se separan por comas La longitud de una lista es el número de elementos que contiene Una lista puede contener un número finito de elementos Los elementos de una lista pueden ser, a su vez, listas Existe una lista especial denominada lista vacía ([]) cuya longitud es cero 3 of 1
4 Qué es una lista? Ejemplos [antonio, luis, andrea, marta, pepe] [antonio, Z, 14, correr(maria), antonio] [antonio, saltar(pepe), [14, K, maria], luis] [] [[pepe,[luis, [maria]]], X, [], 92, correr(luis), []] 4 of 1
5 Operador Las listas no vacías en Prolog pueden descomponerse en cabeza y cola. Sin embargo, una lista vacía por definición no puede descomponerse de esta manera La cabeza y la cola de una lista se definen como sigue: La cabeza de una lista es su primer elemento La cola de una lista es una lista compuesta por todos los elementos que no son la cabeza El operador es posiblemente el operador más importante en Prolog para la manipulación de listas de elementos. Está destinado a realizar la descomposición de una lista en su cabeza y su cola 5 of 1
6 Operador A continuación podemos ver varios ejemplos del uso del operador : 6 of 1
7 Operador El operador permite obtener los primeros n elementos de una lista. Para ello hay que especificar n variables a la izquierda del operador. A continuación se muestran ejemplos en los que se extraen 1, 2 y 3 primeros elementos de una lista: 7 of 1
8 Operador Qué sucede si solo nos interesa el quinto elemento de una lista? Efectivamente, mediante la consulta anterior hemos obtenido el quinto elemento de la lista, tal como deseábamos. Sin embargo, tenemos mucha más información adicional e irrelevante para nosotros 8 of 1
9 Operador En aquellos casos en que no se esté interesado en información adicional a nuestra consulta, se puede evitar que el intérprete nos la proporcione empleando la variable anónima:. A continuación podemos ver un ejemplo de su uso: 9 of 1
10 Operador De forma similar, pueden extraerse únicamente elementos contenidos en listas anidadas. A continuación podemos ver un ejemplo de esto: 10 of 1
11 El predicado member Objetivo: definir un predicado en Prolog que determine si un cierto elemento se encuentra en una lista El predicado propuesto debe tener dos argumentos: 1. El elemento a buscar 2. La lista en la que buscar 11 of 1
12 El predicado member Un elemento está en una lista si es el primer elemento de la misma. Esto significa que el elemento a buscar coincide con la cabeza de la lista. Se puede expresar en Prolog con el siguiente hecho: member(elemento, [Elemento Cola]). 12 of 1
13 El predicado member Por otro lado, un elemento está en una lista en la que no es su cabeza si está en la cola de la misma. Dado que la cola de una lista es, a su vez, una lista, podemos emplear el predicado member de forma recursiva para comprobarlo. Esto puede expresarse a través de la siguiente regla: member(elemento, [Cabeza Cola]) :- member(elemento, Cola). 13 of 1
14 El predicado member La definición del predicado member la guardamos en un fichero de texto denominado mypredicatemember.pl. Este fichero debe ser cargado en el intérprete antes de poder emplear el predicado. A continuación podemos ver ejemplos del uso: 14 of 1
15 El predicado member Podemos también consultar cuáles son los elementos miembros de una determinada lista. A continuación vemos un ejemplo: 15 of 1
16 El predicado deleteall Objetivo: definir un predicado en Prolog que elimine un cierto elemento de una lista tantas veces como aparezca El predicado propuesto debe tener tres argumentos: 1. La lista en la que queremos eliminar 2. El elemento a eliminar 3. La lista obtenida al haber eliminado el elemento 16 of 1
17 El predicado deleteall Si la lista se encuentra vacía, cualquier elemento que se quiera eliminar da como resultado otra lista vacía. Esto se puede expresar en Prolog con el siguiente hecho: deleteall([],, []). 17 of 1
18 El predicado deleteall Por otro lado, si el elemento a eliminar es el primero de la lista, la lista resultante no se ve afectada en forma alguna. Además, en tal caso, se procede a eliminar el elemento de la cola de la lista. Esto puede expresarse a través de la siguiente regla: deleteall([cabeza Cola], Elemento, Resultado) :- Cabeza = Elemento, deleteall(cola, Elemento, Resultado). 18 of 1
19 El predicado deleteall Por último, si el elemento a eliminar no es el primero de la lista, la lista resultante debe tener como cabeza ese mismo elemento dado que no va a eliminarse. Además, al igual que en la regla anterior, debemos eliminar el elemento de la cola de la lista. Esto puede expresarse a través de la siguiente regla: deleteall([cabeza Cola],Elemento,[Cabeza Resultado]) :- dif(cabeza, Elemento), deleteall(cola,elemento,resultado) 19 of 1
20 El predicado deleteall La definición del predicado deleteall la guardamos en un fichero de texto denominado mypredicatedeleteall.pl. Este fichero debe ser cargado en el intérprete antes de poder emplear el predicado. A continuación podemos ver ejemplos del uso: 20 of 1
21 El predicado append Objetivo: definir un predicado en Prolog que concatene dos listas de elementos El predicado propuesto debe tener tres argumentos: 1. La primera de las listas a cuyos elementos van a concatenarse los de la siguiente lista 2. La segunda de las listas cuyos elemento van a ser concatenados a los de la anterior lista 3. La lista obtenida al haber concatenado los elementos de las dos listas anteriores 21 of 1
22 El predicado append Si la primera de las listas se encuentra vacía, la lista resultante es la misma que la segunda de las listas. Esto puede expresarse a través del siguiente hecho: append([], Lista, Lista). 22 of 1
23 El predicado append Si la primera lista no se encuentra vacía (tiene cabeza y cola), la lista resultante tiene como cabeza la cabeza de la primera lista y como cola la concatenación de los elementos que integran la cola de la primera lista y los de la segunda lista. Esto puede expresarse a través de la siguiente regla: append([cabeza Cola], Lista,[Cabeza ColaResultado]) :- append(cola, Lista, ColaResultado). 23 of 1
24 El predicado append La definición del predicado append la guardamos en un fichero de texto denominado mypredicateappend.pl. Este fichero debe ser cargado en el intérprete antes de poder emplear el predicado. A continuación podemos ver ejemplos del uso: 24 of 1
25 Librería lists.pl Esta librería proporciona un amplio conjunto de predicados destinados a la manipulación de listas en Prolog Algunos de los predicados definidos en la librería son: member, append, select, delete, reverse, subset, union, same length, etc. La librería se encuentra cargada por defecto en SWI Prolog. De esta forma, los predicados definidos en ella pueden ser empleados sin necesidad de realizar ninguna operación Documentación acerca de la librería: http: // 25 of 1
26 Librería lists.pl A continuación podemos ver un ejemplo de su uso: Debe notarse aquí que no se realizado la carga de ningún fichero de predicados para poder hacer uso de la librería. 26 of 1
27 Inteligencia Artificial: Prolog Listas Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) 27 of 1
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Aritmética Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) Contenidos Introducción a la Aritmética
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Recursión Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) Contenidos Concepto de Recursión Recursión
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Unificación en Prolog Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) Contenidos Satisfacer objetivos
Secuencias en Python. Introducción a la Computación Clase 11 Patricia Borensztejn
Secuencias en Python Introducción a la Computación Clase 11 Patricia Borensztejn Una cadena es una secuencia En Python tenemos los tipos de datos Escalares: enteros, flotantes Secuencias: sucesión de elementos
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Introducción al Lenguaje de Programación Prolog Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España)
Clustering. Departamento de Ingeniería Informática y de Sistemas Universidad de La Laguna
Clustering Christopher Expósito Izquierdo Airam Expósito Márquez Israel López Plata Belén Melián Batista J. Marcos Moreno Vega {cexposit, aexposim, ilopezpl, mbmelian, jmmoreno}@ull.edu.es Departamento
Listas en Prolog. Capítulo. Listas como sujetos
Capítulo 5 Listas en Prolog Este capítulo introduce el concepto de lista, un tipo de dato de gran influencia dentro de la inteligencia artificial. Se comienza con una introducción a listas en Prolog y
Programación Funcional en LISP Lógica para Ciencias de la Computación
Programación Funcional en LISP Lógica para Ciencias de la Computación Primer Cuatrimestre de 2009 Material Adicional Introducción A lo largo de la carrera estudiaremos diversos paradigmas de programación:
Tipos algebraicos y abstractos. Algoritmos y Estructuras de Datos I. Tipos algebraicos
Algoritmos y Estructuras de Datos I 1 cuatrimestre de 009 Departamento de Computación - FCEyN - UBA Programación funcional - clase Tipos algebraicos Tipos algebraicos y abstractos ya vimos los tipos básicos
Prolog: Listas (y II) MRC
Prolog: Listas (y II) MRC Víctor Peinado [email protected] 11 de diciembre de 2014 Referencias (Blackburn, et al., 2006, chap. 6) 1 1 Blackburn, P., Bos, J., Striegnitz, K. Learn Prolog Now!. College
Aplicación de la Inducción Matemática Programación Funcional. Julio Ariel Hurtado Alegría Departamento de Sistemas Universidad del Cauca
Aplicación de la Inducción Matemática Programación Funcional Julio Ariel Hurtado Alegría Departamento de Sistemas Universidad del Cauca Motivación Programación Imperativa Declarativa Procedimental Ejemplo:
FUNCIONES DE CADENAS DE CARACTERES (STRINGS) EN PHP. CONCATENACIÓN. STRLEN (LONGITUD) Y SUBSTR (EXTRAER SUBCADENA). (CU00821B)
APRENDERAPROGRAMAR.COM FUNCIONES DE CADENAS DE CARACTERES (STRINGS) EN PHP. CONCATENACIÓN. STRLEN (LONGITUD) Y SUBSTR (EXTRAER SUBCADENA). (CU00821B) Sección: Cursos Categoría: Tutorial básico del programador
La Herramienta Redmine para la Administración de Proyectos
La Herramienta Redmine para la Administración de Proyectos 9. Personalización y configuración inicial de la herramienta Redmine v1.0.2 Mag. José Eduardo Rodríguez Esquivel [email protected]
PERIODO 3 SOFTWARE MANEJADOR DE BASE DE DATOS CONCEPTOS INTERMEDIOS DE MICROSOFT ACCESS
PERIODO 3 SOFTWARE MANEJADOR DE BASE DE DATOS CONCEPTOS INTERMEDIOS DE MICROSOFT ACCESS CONTENIDOS PROPIEDADES DE LOS CAMPOS TAMAÑO DEL CAMPO FORMATO DEL CAMPO LUGARES DECIMALES MÁSCARA DE ENTRADA TÍTULO
Programación Declarativa Ejercicios de programación con listas
Programación Declarativa Ejercicios de programación con listas Ejercicio 1 Define versiones recursivas de los siguientes predicados sobre listas: es lista(xs) Xs es una lista bien formada es lista nat(ss)
Lenguajes de Programación Programación funcional
Lenguajes de Programación Programación funcional Roberto Bonvallet Departamento de Informática Universidad Técnica Federico Santa María Concepto de función En el paradigma imperativo: Una función es una
Compiladores: Sesión 3. Análisis léxico, expresiones regulares
Compiladores: Sesión 3. Análisis léxico, expresiones regulares Prof. Gloria Inés Alvarez V. Departamento de Ciencias e Ingeniería de la Computación Pontificia Universidad Javeriana Cali 29 de enero de
1. Define que es un Autómatas finitos determinanticos y cuáles son sus elementos constitutivos (explique cada uno de ellos).
Unidad 2.- Lenguajes Regulares Los lenguajes regulares sobre un alfabeto dado _ son todos los lenguajes que Se pueden formar a partir de los lenguajes básicos?, {_}, {a}, a 2 _, por medio De las operaciones
Trabajo Práctico 2 - Programación Lógica Viajante de comercio Fecha de entrega: jueves 30 de octubre, hasta las 21 hs.
Trabajo Práctico 2 - Programación Lógica Viajante de comercio Fecha de entrega: jueves 30 de octubre, hasta las 21 hs. 1. Mapas y rutas Una empresa de transporte desea organizar su logística. Para ello,
El SQL es un lenguaje estándar de programación para el acceso a bases de datos.
El SQL es un lenguaje estándar de programación para el acceso a bases de datos. El lenguaje SQL se utiliza para acceder y manipular datos en cualquier base de datos del mercado, como por ejemplo, para
ESTRUCTURAS DE DATOS Y ALGORITMOS
ESTRUCTURAS DE DATOS Y ALGORITMOS CURSO 2009 PRÁCTICO 8 Nota: al igual que en los prácticos 6 y 7, en los problemas que siguen se usarán los tipos lista y árbol binario, como tipos abstractos, cada uno
LENGUAJES Y GRAMÁTICAS
LENGUAJES Y GRAMÁTICAS LENGUAJES Y GRAMÁTICAS La sintaxis de un lenguaje natural en lenguajes como el ingles, español, alemán o francés es extremadamente complicada, dado que es imposible especificar la
Introducción a la Programación Lógica. Ingeniería Informática Departamento de Lenguajes y Ciencias de la Computación Universidad de Málaga
Introducción a la Programación Lógica Ingeniería Informática Departamento de Lenguajes y Ciencias de la Computación Universidad de Málaga Programming in Prolog opens the mid to a new way of looking at
Introducción a la Programación en C Funciones
Christopher Expósito-Izquierdo [email protected] Airam Expósito-Márquez [email protected] Israel López-Plata [email protected] Belén Melián-Batista [email protected] José Marcos Moreno-Vega [email protected]
Tema 2. Fundamentos de la Teoría de Lenguajes Formales
Departamento de Tecnologías de la Información Tema 2. Fundamentos de la Teoría de Lenguajes Formales Ciencias de la Computación e Inteligencia Artificial Índice 2.1. Alfabeto 2.2. Palabra 2.3. Operaciones
roducción a la programación con el lenguaje C usando el entorno de trabajo Dev-C. Nociones básicas de programación
There are no translations available. Introducción a la programación con el lenguaje C usando el entorno de trabajo Dev-C. roducción a la programación con el lenguaje C usando el entorno de trabajo Dev-C.
Tipos Recursivos de Datos
1/1 Tipos Recursivos de Datos Josefina Sierra Santibáñez 27 de noviembre de 2016 2/1 Introducción La recursividad no sólo se puede aplicar a la definición de procedimientos (i.e. funciones o acciones),
STRINGBUFFER, STRINGBUILDER JAVA. EJEMPLO. DIFERENCIAS ENTRE CLASES. CRITERIOS PARA ELEGIR. MÉTODOS. (CU00914C)
APRENDERAPROGRAMAR.COM STRINGBUFFER, STRINGBUILDER JAVA. EJEMPLO. DIFERENCIAS ENTRE CLASES. CRITERIOS PARA ELEGIR. MÉTODOS. (CU00914C) Sección: Cursos Categoría: Lenguaje de programación Java nivel avanzado
M a tl a b. Oriol Roca ARREGLOS EN MATLAB.
ARREGLOS EN MATLAB Arreglos Estructura de datos que permite almacenar varios datos bajo el mismo nombre. VECTORES: son unidimensionales 0 2 4 6 8 VS egu e crida t od en r ei nstern et Vectores Para crear
Tipos de Datos Recursivos
1/1 Tipos de Datos Recursivos Josefina Sierra Santibáñez 15 de mayo de 2018 2/1 Introducción La recursividad no sólo se puede aplicar a la definición de procedimientos (i.e. funciones o acciones), sino
Introducción a ASP (Answer Set Programming - programación con conjuntos respuestos)
Introducción a ASP (Answer Set Programming - programación con conjuntos respuestos) Inteligencia Artificial David Pearce 13 de enero de 2009 ASP y programación declarativa ASP es una forma de programación
Tema 6: Estructuras de datos recursivas
Tema 6: Estructuras de datos recursivas Índice 1 Listas jerárquicas...2 2 Árboles binarios... 4 3 Árboles genéricos...7 4 Referencias...10 1. Listas jerárquicas Las listas tienen la propiedad de la clausura
Estructuras incompletas. Listas diferencia.
Estructuras incompletas. Listas diferencia. 1 / 13 Estructuras incompletas Proporcionan una técnica de implementación muy potente propia de Prolog: Incrementan radicalmente la eficiencia de muchos programas.
Representación de números en la recta real. Intervalos
Representación de números en la recta real. Intervalos I. Los números reales En matemáticas los números reales se componen de dos grandes grupos: los números racionales (Q) y los irracionales (I). A su
Tema 2: Introducción a la programación con Haskell
Programación declarativa (2010 11) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 2. 4. 2 / 26 El sistema GHC El sistema GHC
Tema 2: Introducción a la programación con Haskell
Tema 2: Introducción a la programación con Haskell Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad
Funciones GOTO computables
Funciones GOTO computables Dpto. Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Lógica Matemática Curso 2011 12 LM, 2011 12 Lenguaje GOTO 4.1 Contenido El lenguaje GOTO Sintaxis
Guía 2: Listas, recursión e inducción
Introducción a los Algoritmos - 2do cuatrimestre 2014 Guía 2: Listas, recursión e inducción Docentes: Walter Alini, Luciana Benotti En esta guía comenzaremos a trabajar con listas Para familiarizarnos
Parte de Algoritmos, de la asignatura de Programación Máster de Bioinformática Cadenas y expresiones regulares
Parte de Algoritmos, de la asignatura de Programación Máster de Bioinformática Departamento de Informática y Sistemas Universidad de Murcia http://dis.um.es/ domingo/algbio.html [email protected] Contenido
TUTORIAL PROLOG. Lenguajes de programación Universidad Nacional de Colombia Santiago Carvajal Castañeda Mario Andrés Moreno Norato
TUTORIAL PROLOG Lenguajes de programación Universidad Nacional de Colombia Santiago Carvajal Castañeda Mario Andrés Moreno Norato Prolog es un lenguaje de programación lógica de propósito general que se
Tema 3: Gramáticas regulares. Teoría de autómatas y lenguajes formales I
Tema 3: Gramáticas regulares Teoría de autómatas y lenguajes formales I Bibliografía Hopcroft, J. E., Motwani, R., y Ullman, J. D. Introducción a la Teoría de Autómatas, Lenguajes y Computación. Addison
TEMA 1: Los números reales. Tema 1: Los números reales 1
TEMA 1: Los números reales Tema 1: Los números reales 1 ESQUEMA DE LA UNIDAD 1.- Números naturales y enteros..- Números racionales. 3.- Números irracionales. 4.- Números reales. 5.- Jerarquía en las operaciones
TEORÍA DE AUTÓMATAS Y LENGUAJES
TEORÍA DE AUTÓMATAS Y LENGUAJES FORMALES Francisco Vico departamento Lenguajes y Ciencias de la Computación área de conocimiento Ciencias de la Computación e Inteligencia Artificial ETSI Informática Universidad
SESIÓN PRÁCTICA 3: TRANSFORMACIONES DE DATOS PROBABILIDAD Y ESTADÍSTICA. PROF. Esther González Sánchez. Departamento de Informática y Sistemas
SESIÓN PRÁCTICA 3: TRANSFORMACIONES DE DATOS PROBABILIDAD Y ESTADÍSTICA PROF. Esther González Sánchez Departamento de Informática y Sistemas Facultad de Informática Universidad de Las Palmas de Gran Canaria
Práctica 6: Consultas
Práctica 6: Consultas INTRODUCCIÓN Para la realización de las siguientes prácticas el alumno debe descargar el fichero EMPRESA.ZIP, que contiene la base de datos objeto de las prácticas. La base de datos
DEL AUTÓMATA FINITO A LA EXPRESIÓN REGULAR
DEL AUTÓMATA FINITO A LA EXPRESIÓN REGULAR Muchas veces es más fácil y seguro dibujar el DT de un AF que reconozca al lenguaje, para luego obtener la ER a partir de este autómata. Se presenta un método
5.3 Tipos de Datos en Prolog
5.3 Tipos de Datos en Prolog Objetos de Datos en Prolog Objetos de datos simples Objetos estructurados Calce de operaciones fundamentales sobre objetos 1 Tipos de Objetos de Datos Objetos de datos Objetos
5.3 Tipos de Datos en Prolog
5.3 Tipos de Datos en Prolog Objetos de Datos en Prolog Objetos de datos simples Objetos estructurados Calce de operaciones fundamentales sobre objetos Tipos de Objetos de Datos Objetos de datos Objetos
Tema 5. Otros lenguajes de consulta relacionales
Tema 5. Otros lenguajes de consulta relacionales Juan Ignacio Rodríguez de León Resumen Estudio de otros lenguajes relacionales de consulta orientados a usuarios. QED (Query by example). QUEL. (Lenguaje
5.3 Tipos de Datos en Prolog
5.3 Tipos de Datos en Prolog Recocimiento de Tipos Se recoce el tipo de un dato por su forma sintáctica; se requiere de declaración de tipos Ejemplo: Variables se definen comienzan con primera en mayúsculas
Fundamentos de Bases de Datos
1.- DATOS DE LA ASIGNATURA Nombre de la asignatura: Carrera: Clave de la asignatura: Horas teoría-horas práctica-créditos Fundamentos de Bases de Datos Ingeniería en Sistemas Computacionales SCM - 0412
Estructuras de Datos y Listas en PROLOG. 1. Estructuras y árboles 2. Listas 3. Operaciones con Listas 4. Ejercicios 5. Prácticas
Estructuras de Datos y Listas en PROLOG 1. Estructuras y árboles 2. Listas 3. Operaciones con Listas 4. Ejercicios 5. Prácticas 1. Estructuras y árboles Una estructura de datos en PROLOG se puede visualizar
AMZI! PROLOG. Inteligencia Artificial. Componentes básicas. Componentes adicionales. Listener. Componentes y Archivos
AMZI! PROLOG Inteligencia Artificial AMZI! PROLOG Proyectos de Cursado 2º cuatrimestre 2004 Amzi! Prolog + Logic Server consiste de componentes básicas para distintas plataformas junto con componentes
Inteligencia Artificial II Prolog I
Inteligencia Artificial II Prolog I Dr. Alejandro Guerra-Hernández Universidad Veracruzana Centro de Investigación en Inteligencia Artificial mailto:[email protected] http://www.uv.mx/personal/aguerra Maestría
Programación Declarativa Haskell Informática Sistemas Curso Pepe Gallardo Universidad de Málaga. Tema 8. Listas
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 8. Listas 8.1 Secuencias aritméticas 8.2 Algunas funciones predefinidas 8.3 Listas por comprensión
INTRODUCCIÓN A LA POO EN C++
INTRODUCCIÓN A LA POO EN C++ ÍNDICE DEL TEMA 1.- Introducción 2.- Diferencias C/C++ 3.- Programación orientada a objetos 4.- Aspectos avanzados C++ 1 1. Introducción Lenguaje C Lenguaje de propósito general
Ejercicio 2 Considere la representación para Lista de Naturales y Árbol Binario de Naturales de la Figura 1.
Ejercicios Resueltos del Práctico 4 Ejercicio 2 Considere la representación para Lista de Naturales y Árbol Binario de Naturales de la Figura 1. 1 2 struct NodoLista { 3 int elem ; 4 NodoLista * sig ;
PROGRAMACIÓN ORIENTADA A LA INTELIGENCIA ARTIFICIAL
PROGRAMACIÓN ORIENTADA A LA INTELIGENCIA ARTIFICIAL Ejercicios de programación en LISP y PROLOG [email protected] Dpto. Inteligencia Artificial E.T.S.I. Informática (UNED) C/ Juan del Rosal 16 28040
Introducción a la Programación en C
Christopher Expósito-Izquierdo [email protected] Airam Expósito-Márquez [email protected] Israel López-Plata [email protected] Belén Melián-Batista [email protected] José Marcos Moreno-Vega [email protected]
Introducción a PROLOG
Inteligencia Artificial II Curso 2003 2004 Introducción a PROLOG Carmen Graciani Díaz José L. Ruiz Reina Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla IA-II 2003
Formularios: pantallas que se presentan a los usuarios de una base de datos para que tengan un acceso amigable a los datos y operaciones.
Objetivos curso: Una base de datos se puede considerar como un archivo que contiene datos (estructurados e interrelacionados) y los objetos que definen y manejan esos datos: tablas, consultas, formularios,
Tema 3. Patrones y Definiciones de Funciones
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 3. Patrones y Definiciones de Funciones 3.1 Comparación de Patrones Patrones constantes Patrones
Departamento de Inteligencia Artificial Facultad de Informática Universidad Politécnica de Madrid
LÓGICA FORMAL Lógica Proposicional: Teorema de Efectividad Departamento de Inteligencia Artificial Facultad de Informática Universidad Politécnica de Madrid Lógica Proposicional 1 La lógica proposicional
Modulo I: Introducción Gestores de Bases De Datos
Modulo I: Introducción Gestores de Bases De Datos El SQL El SQL (Lenguaje de Consulta Estructurado Structure Query Language), es un lenguaje de consulta estructurado establecido claramente como el lenguaje
Informática Haskell Matemáticas Curso Pepe Gallardo Universidad de Málaga. Tema 8. Listas
Informática Haskell Matemáticas Curso 2004-2005 Pepe Gallardo Universidad de Málaga Tema 8. Listas 8.1 Secuencias aritméticas 8.2 Algunas funciones predefinidas 8.3 Listas por comprensión Ejemplo: QuickSort
Tema 4.- Recursión e iteración
UNIVERSIDAD DE CÓRDOBA ESCUELA POLITÉCNICA SUPERIOR DE CÓRDOBA DEPARTAMENTO DE INFORMÁTICA Y ANÁLISIS NUMÉRICO PROGRAMACIÓN DECLARATIVA INGENIERÍA INFORMÁTICA ESPECIALIDAD DE COMPUTACIÓN CUARTO CURSO PRIMER
Tema 4: Programación funcional avanzada en Scheme
Tema 4: Programación funcional avanzada en Scheme Índice 1 Let... 2 2 Let*... 5 3 Letrec... 5 4 Quote...6 5 Eval... 7 6 Datos compuestos: parejas...8 7 Los datos compuestos pueden ser funciones...11 8
Tema 3. Listas Recursión sobre datos
Tema 3 Listas Recursión sobre datos José A. Alonso M. José Hidalgo Álvaro Romero Dpto. Ciencias de la Computación e Inteligencia Artificial UNIVERSIDAD DE SEVILLA Informática ListasRecursión sobre datos
Inteligencia Artificial (IS). Curso Trabajo sobre Inferencia en Redes Bayesianas
Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Inteligencia Artificial (IS). Curso 2016-17 Trabajo sobre Inferencia en Redes Bayesianas Esta propuesta pretende construir
Programación Declarativa
Programación Declarativa Tema 2: LISP (SCHEME) 2 Tema 2: LISP (SCHEME) Introducción Representación de Datos Definición de Funciones Predicados Listas 3 Introducción (I) SCHEME es un dialecto de LISP (LISt
Tema 12.- Entrada y Salida
UNIVERSDAD DE CÓRDOBA ESCUELA POLITÉCNICA SUPERIOR DEPARTAMENTO DE INFORMÁTICA Y ANÁLISIS NUMÉRICO LENGUAJES DE INTELIGENCIA ARTIFICIAL INGENIGERÍA TÉCNICA EN INFORMÁTICA DE GESTIÓN INGENIERÍA TÉCNICA
Usando los operadores SET (Conjunto)
Usando los operadores SET (Conjunto) Objetivos del capítulo Describir los operadores SET (Conjunto) Usar un operador SET (Conjunto) para combinar múltiples consultas en una consulta simple Controlar el
Metodologías de Programación II Listas en Lisp
Metodologías de Programación II Listas en Lisp Dr. Alejandro Guerra-Hernández Departamento de Inteligencia Artificial Facultad de Física e Inteligencia Artificial [email protected] http://www.uv.mx/aguerra
PROGRAMACIÓN ORIENTADA A LA INTELIGENCIA ARTIFICIAL
PROGRAMACIÓN ORIENTADA A LA INTELIGENCIA ARTIFICIAL Ejercicios de programación en LISP y PROLOG Angeles Manjarrés Riesco Severino Fernández Galán Jesús González Boticario [email protected] Dpto. Inteligencia
Tema 6: Funciones recursivas
Tema 6: Funciones recursivas Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 6: Funciones
Tema 09: TAD Árbol binario
Tema 09: TAD Árbol binario M. en C. Edgardo Adrián Franco Martínez http://www.eafranco.com [email protected] @edfrancom edgardoadrianfrancom (Prof. Edgardo A. Franco) 1 Contenido Introducción El árbol binario
6. Operadores en PROLOG
6. Operadores en PROLOG 1. Definición de operadores propios 2. Operadores predefinidos Igualdad Entrada y Salida básicos Manejo de ficheros Evaluación de expresiones aritméticas Comparación de números
