Diseño de Algoritmos resolver problemas y diseñar algoritmos
Enviado por monto2435 • 11 de Julio de 2018 • 4.609 Palabras (19 Páginas) • 494 Visitas
...
- Es un conjunto de acciones que determinan la secuencia de pasos a seguir para resolver un problema específico.
- Son finitos, es decir, sus pasos terminan en algún punto determinado.
- Es una forma de resolver un problema.
[pic 1]
- Es un proceso con datos de entrada y de salida (llamados resultados).
[pic 2]
Según Luis Joyanes Aguilar (Métodología de la Programación, 1988), establece una serie técnicas usadas para la resolución de problemas, entre ellas podemos mencionar:
-
Refinamiento por pasos
Según Regulo Salas/Dolores Ríos (Esprosistemas, 1989). Enfoca la solución de los problemas de afuera hacia adentro resolviendo aspectos generales para entrar a definir finalmente los detalles.
Características:
- Un problema complejo puede descomponerse en un conjunto de problemas equivalentes, cada uno de los cuales es de menor complejidad que el problema original.
- La solución de todos los problemas menores conduce a la solución del problema inicial.
- Cada problema menor (subproblema) puede descomponerse, a su vez, en problemas menores de más fácil solución.
- La descomposición debe seguirse hasta que un problema menor tenga solución inmediata.
- La solución final estará formada por la concatenación ordenada de todos los problemas menores que resultaron de la descomposición.
- Si uno de los problemas menores no se pudiera resolver, el problema original tampoco tendría solución.
Forma gráfica
[pic 3]
Cuando en la aplicación de ésta técnica se llega a un problema (subproblema) que puede resolverse mediante una estructura secuencial, repetitiva o selectiva, entonces el problema menor ya no se sigue refinando más.
Pasos:
- Analizar las estructuras que conforman el problema principal.
- Dividir el problema en tantas partes como estructuras independientes se hayan encontrado.
- Analizar cada una de las estructuras por separado y aplicarles el mismo principio hasta llegar a la solución compuesta por elementos básicos o combinaciones de ellos, hasta que no pueda identificar una estructura dentro de otra estructura.
Ejemplo: Se desea procesar los datos de un grupo de estudiantes por cada estructura se encuentra la siguiente información de entrada (nombre, sexo, carrera, lugar de nacimiento). Se pide un informe en que aparezcan los nombres de los estudiantes que cumplan las siguientes condiciones: sexo femenino, estudiante de sistemas, nacidos en Valera.
Solución: El problema presenta una estructura de tipo repetitivo, en la cual se leen los datos de entrada y luego se procesan.
Refinando por pasos
Estructura global →Problema →Lectura de datos. Procesos
[pic 4]
[pic 5]
Ventajas
Permite visualizar la descomposición en problemas menores
Inconvenientes
Lograr la división de un problema en subproblemas.
-
Pseudocódigo (pseudolenguaje)
- Es una mezcla de lenguaje de programación y español (o cualquier otro idioma).
- Se emplea en la programación estructurada para realizar el diseño de un programa.
- Es un metalenguaje simbólico para la especificación de los pasos de un algoritmo.
- Imitación y una versión abreviada de instrucciones.
- Utilizan palabras claves.
- Es una técnica para expresar en lenguaje natural la lógica de un programa (flujo de control).
Ejemplos
El mismo de refinamiento por pasos:
- Inicio del algoritmo Estudiante
- Definir haydato, nombre, sexo, carrera, nac
- Haydato=´s´
- Haga mientras haydato=´s´
Comienzo
- Leer (nombre, sexo, carrera, nac)
- Si sexo = ´f´ entonces
Si carrera = ´sistemas´entonces
Si nac = ´Valera´ entonces
Imprimir (´nombre´)
Sino
Continuar
Fin_Si
Sino
Continuar
Fin_Si
- Leer (haydato) /*Lee el nombre del estudiante que cumple con las condiciones
Fin_Haga_mientras
- Fin_Inicio
Otro Ejemplo
- Inicio del algoritmo Figura
- Defina opc, a, b, h, l, r
- Leer opc
- Si opc = 1 entonces
- Leer b, h
- A = (b*h)/2
Fin_Si
- Si opc = 2 entonces
- Leer l
- A = l * l
Fin_Si
- Si opc = 3 entonces
- Leer
...