RecursiónLa recursión o recursividad es la posibilidad que tiene un cierto tipo de unidad o proceso de contenerse o aplicarse a sí mismo indefinidamente. La recursión tiene esta característica discernible en términos de autorreferencialidad, autopoiesis, fractalidad o, en otras palabras, construcción a partir de un mismo tipo. Con ánimo de una mayor precisión, y para evitar la aparente circularidad en esta definición, se formula el concepto de recursión de la siguiente manera: Un problema que pueda definirse en función de su tamaño, sea este N, puede dividirse en instancias más pequeñas (< N) del mismo problema y se conocerá la solución explícita a las instancias más simples, lo que se conoce como casos base, y se puede aplicar inducción sobre las llamadas más pequeñas y suponer que estas quedan resueltas.[cita requerida] A continuación se exponen algunos ejemplos:
En estos ejemplos puede observarse cómo un problema se divide en varias (una o más) instancias del mismo problema, pero de tamaño menor, gracias a lo cual se puede aplicar inducción, llegando a un punto donde se conoce el resultado (el caso base).[cita requerida] Recursión en matemáticasConjuntos definidos de forma recurrenteUn ejemplo de conjunto definido de forma recurrente es el de los números naturales, es decir, el conjunto de los números enteros no negativos:[1]
Funciones definidas de forma recurrenteAquellas funciones cuyo dominio es un conjunto a lo más enumerable pueden ser definidas de forma recurrente.[2] Un ejemplo conocido es la definición recurrente de la función factorial n!: Veamos cómo se usa esta definición para hallar el valor del factorial de 3: Otros ejemplos de funciones y sucesiones matemáticas definidas de forma recursiva son:
ConstantesLa razón áurea se puede definir de forma recursiva, como una fracción continua en que todos los números son unos:
De forma similar, la identidad da lugar a una definición como fracción continua de cualquier raíz cuadrada:[3] Resolución de problemasResolución de ecuaciones homogéneas de primer grado, segundo orden: a) Se pasan al primer miembro los términos , , , los cuales también podrían figurar como , , b) Se reemplaza por , por y por , quedando una ecuación de segundo grado con raíces reales y distintas y . c) Se plantea d) Debemos tener como dato los valores de los dos primeros términos de la sucesión: y . Utilizando estos datos ordenamos el sistema de 2x2: La resolución de este sistema nos da como resultado los valores y , que son números reales conocidos. e) La solución general es: Recursión en informáticaEn programación, un método usual de simplificación de un problema complejo es la división de este en subproblemas del mismo tipo. Esta técnica de programación se conoce como divide y vencerás y es el núcleo en el diseño de numerosos algoritmos de gran importancia, así como también es parte fundamental de la programación dinámica. Implementación en C: int factorial (int n)
{
if (n > 1)
{
return n * factorial(n-1);
}else
{
return 1;
}
}
int main()
{
printf("Recusividad\n");
int result = factorial(5);
printf("El resultado es: %i", result);
return 0;
}
Implementación en C++: int factorial(int x)
{
if (x > -1 && x < 2) return 1; // Cuando -1 < x < 2 devolvemos 1 puesto que 0! = 1 y 1! = 1
else if (x < 0) return 0; // Error no existe factorial de números negativos
return x * factorial(x - 1); // Si x >= 2 devolvemos el producto de x por el factorial de x - 1
}
Implementación en Pascal: FUNCTION Factorial (CONST N: INTEGER): INTEGER;
BEGIN
IF N > 1 THEN
Factorial := N * (Factorial (N - 1));
ELSE
BEGIN
IF ((N=0) OR (N=1))
Factorial := 1;
ELSE
Factorial := 0;
END;
END;
END;
def factorial(n):
if n == 1 or n == 0:
return 1
else:
return n * factorial(n-1)
El seguimiento de la recursividad programada es casi exactamente igual a los ejemplos antes dados, para intentar ayudar a que se entienda mejor se ha acompañado con muchas explicaciones y con colores que diferencia los distintos sub-procesos de la recursividad. X = 3 //Queremos 3!, por lo tanto X inicial es 3 X >= 2 -> return 3*factorial(2); X = 2 //Ahora estamos solicitando el factorial de 2 X >= 2 -> return 2*factorial(1); X = 1 // Ahora estamos solicitando el factorial de 1 X < 2 -> return 1; [En este punto tenemos el factorial de 1 por lo que volvemos marcha atrás resolviendo todos los resultados] return 2 [es decir: return 2*1 = return 2*factorial(1)] return 6 [es decir: return 3*2 = return 3*factorial(2)*factorial(1)] // El resultado devuelto es 6 Recursión en las ciencias socialesEl concepto de recursión o recursividad está en el centro de los debates epistemológicos en ciencias sociales, y se refiere a la situación en que los científicos sociales se encuentran al intentar producir conocimiento acerca de un mundo del que ellos mismos son parte.[5][6] Según Audrey Alejandro, "como científicos sociales, la recursividad de nuestra condición alude al hecho de que somos a la vez sujetos (pues el discurso es el medio por el cual analizamos) y objetos de los discursos académicos que producimos (pues somos agentes sociales dentro del mundo que analizamos)".[7] Desde esta premisa, identifica en la recursividad un reto fundamental en la producción de conocimiento que requiere nuestra reflexión:
Humor recursivoLa recursividad se emplea a menudo de forma humorística en textos informáticos, filosóficos o matemáticos. No es raro que un libro de texto de estas disciplinas incluya en su glosario una entrada similar a esta:
En el buscador Google, al buscar «recursión», el sitio sugiere «Quizá quisiste decir: recursión».[10] Un chiste informático dice así«:Lo primero para entender la recursividad, es entender la recursividad».[9] En la informática también es común la elección de acrónimos recursivos. PHP son las iniciales de PHP Hypertext Preprocessor (Preprocesador de Hipertexto PHP), WINE son las de WINE Is Not an Emulator (WINE no es un emulador) y GNU significa GNU's Not Unix (GNU no es Unix). Véase también
Referencias
Enlaces externos |
Portal di Ensiklopedia Dunia