[{"data":1,"prerenderedAt":783},["ShallowReactive",2],{"navigation_docs":3,"-metodos-recursividad":412,"-metodos-recursividad-surround":778},[4,18,43,118,160,200,231,320,346],{"title":5,"path":6,"stem":7,"children":8,"icon":17},"Evaluación","\u002Fintroduction","1.introduction\u002F1.index",[9,12],{"title":10,"path":6,"stem":7,"icon":11},"Método de Evaluación","i-iconamoon-cheque-bold",{"title":13,"path":14,"stem":15,"icon":16},"Plataforma de Aprendizaje","\u002Fintroduction\u002Fplataforma","1.introduction\u002F2.plataforma","i-lucide-book-marked","i-lucide-house",{"title":19,"icon":20,"path":21,"stem":22,"children":23,"page":42},"Entorno de desarrollo","i-codicon-edit-code","\u002Fide","2.ide",[24,28,33,37],{"title":25,"path":26,"stem":27,"icon":20},"¿Qué es un IDE?","\u002Fide\u002Fentorno","2.ide\u002F1.entorno",{"title":29,"path":30,"stem":31,"icon":32},"Estructura de un Proyecto","\u002Fide\u002Festructura","2.ide\u002F2.estructura","i-clarity-tree-view-line",{"title":34,"path":35,"stem":36,"icon":20},"La compilación en un IDE","\u002Fide\u002Fcompilacion","2.ide\u002F3.compilacion",{"title":38,"path":39,"stem":40,"icon":41},"Depuración de Código","\u002Fide\u002Fdepurar","2.ide\u002F4.depurar","i-lucide-bug",false,{"title":44,"icon":45,"path":46,"stem":47,"children":48,"page":42},"Clases y Objetos","i-catppuccin-java-class","\u002Fclases-objetos","3.clases-objetos",[49,53,57,62,66,70,74,78,83,88,92,96,101,106,110,114],{"title":50,"path":51,"stem":52},"Repaso previo a Clases y Objetos","\u002Fclases-objetos\u002Fpreview","3.clases-objetos\u002F00.preview",{"title":54,"path":55,"stem":56,"icon":45},"¿Qué es la Programación Orientada a Objetos (POO)?","\u002Fclases-objetos\u002Fpoo","3.clases-objetos\u002F01.poo",{"title":58,"path":59,"stem":60,"icon":61},"Diagramas de Clases y Objetos","\u002Fclases-objetos\u002Fdiagramas","3.clases-objetos\u002F02.diagramas","i-devicon-uml",{"title":63,"path":64,"stem":65,"icon":45},"Las Clases","\u002Fclases-objetos\u002Fclases","3.clases-objetos\u002F03.clases",{"title":67,"path":68,"stem":69,"icon":45},"Ámbito y Visibilidad","\u002Fclases-objetos\u002Fambito","3.clases-objetos\u002F04.ambito",{"title":71,"path":72,"stem":73,"icon":45},"Declaración e Instanciación de Objetos","\u002Fclases-objetos\u002Fobjetos","3.clases-objetos\u002F05.objetos",{"title":75,"path":76,"stem":77,"icon":45},"Clases Predefinidas en Java","\u002Fclases-objetos\u002Fpredefinidas","3.clases-objetos\u002F06.predefinidas",{"title":79,"path":80,"stem":81,"icon":82},"Paquetes en Java","\u002Fclases-objetos\u002Fpaquetes","3.clases-objetos\u002F07.paquetes","i-material-icon-theme-folder-java-open",{"title":84,"path":85,"stem":86,"icon":87},"Las Excepciones","\u002Fclases-objetos\u002Fexcepciones","3.clases-objetos\u002F08.excepciones","i-catppuccin-java-exception",{"title":89,"path":90,"stem":91,"icon":45},"La clase JOptionPane","\u002Fclases-objetos\u002Fjoptionpane","3.clases-objetos\u002F09.joptionpane",{"title":93,"path":94,"stem":95,"icon":45},"Constructores y Accesores","\u002Fclases-objetos\u002Fconstructores","3.clases-objetos\u002F10.constructores",{"title":97,"path":98,"stem":99,"icon":100},"Tipos Enumerados (Enums)","\u002Fclases-objetos\u002Fenumerados","3.clases-objetos\u002F11.enumerados","i-catppuccin-java-enum",{"title":102,"path":103,"stem":104,"icon":105},"Modificadores de acceso static y final","\u002Fclases-objetos\u002Fmodificadores","3.clases-objetos\u002F12.modificadores","i-mdi-chart-box",{"title":107,"path":108,"stem":109,"icon":105},"El casting en Java","\u002Fclases-objetos\u002Fcasting","3.clases-objetos\u002F13.casting",{"title":111,"path":112,"stem":113},"Las Expresiones Regulares","\u002Fclases-objetos\u002Fexpresiones-regulares","3.clases-objetos\u002F14.expresiones-regulares",{"title":115,"path":116,"stem":117,"icon":105},"Clases Genéricas en Java","\u002Fclases-objetos\u002Fclases-genericas","3.clases-objetos\u002F15.clases-genericas",{"title":119,"icon":120,"path":121,"stem":122,"children":123,"page":42},"Funciones (Métodos)","i-material-symbols-function","\u002Fmetodos","4.metodos",[124,128,132,136,140,144,148,152,156],{"title":125,"path":126,"stem":127},"Funciones Genéricas","\u002Fmetodos\u002Ffuncion-generica","4.metodos\u002F01.funcion-generica",{"title":129,"path":130,"stem":131},"Métodos de Instancia y de Clase","\u002Fmetodos\u002Finstancia-clase","4.metodos\u002F02.instancia-clase",{"title":133,"path":134,"stem":135},"Sobrecarga de Funciones","\u002Fmetodos\u002Fsobrecarga","4.metodos\u002F03.sobrecarga",{"title":137,"path":138,"stem":139},"Alcance de Variables y Métodos","\u002Fmetodos\u002Falcance","4.metodos\u002F04.alcance",{"title":141,"path":142,"stem":143},"Recursividad","\u002Fmetodos\u002Frecursividad","4.metodos\u002F05.recursividad",{"title":145,"path":146,"stem":147},"Puntero this","\u002Fmetodos\u002Fthis","4.metodos\u002F06.this",{"title":149,"path":150,"stem":151},"Los argumentos variables (varargs)","\u002Fmetodos\u002Fvarargs","4.metodos\u002F07.varargs",{"title":153,"path":154,"stem":155},"La clase Arrays","\u002Fmetodos\u002Farrays","4.metodos\u002F08.arrays",{"title":157,"path":158,"stem":159},"Predicados Simples y Compuestos en Java","\u002Fmetodos\u002Fpredicados","4.metodos\u002F09.predicados",{"title":161,"path":162,"stem":163,"children":164,"icon":199},"Herencia","\u002Fherencia","5.herencia\u002F01.index",[165,167,171,175,179,183,187,191,195],{"title":166,"path":162,"stem":163},"¿Qué es la herencia?",{"title":168,"path":169,"stem":170},"Sobreescritura de métodos y uso de `super`","\u002Fherencia\u002Fsobeescritura","5.herencia\u002F02.sobeescritura",{"title":172,"path":173,"stem":174},"Tipos de herencia","\u002Fherencia\u002Ftipos-herencia","5.herencia\u002F03.tipos-herencia",{"title":176,"path":177,"stem":178},"La clase Object en Java","\u002Fherencia\u002Fobject","5.herencia\u002F04.object",{"title":180,"path":181,"stem":182},"Polimorfismo","\u002Fherencia\u002Fpolimorfismo","5.herencia\u002F05.polimorfismo",{"title":184,"path":185,"stem":186},"Clases y Funciones Abstractas","\u002Fherencia\u002Fabstract","5.herencia\u002F06.abstract",{"title":188,"path":189,"stem":190},"Interfaces","\u002Fherencia\u002Finterfaces","5.herencia\u002F07.interfaces",{"title":192,"path":193,"stem":194},"Funciones e Interfaces","\u002Fherencia\u002Ffunciones-interfaces","5.herencia\u002F08.funciones-interfaces",{"title":196,"path":197,"stem":198},"Interfaces y Funciones Lambda","\u002Fherencia\u002Flambda-interface","5.herencia\u002F09.lambda-interface","i-material-symbols-heritage",{"title":201,"path":202,"stem":203,"children":204,"icon":199},"Arreglos","\u002Farreglos","6.arreglos\u002F01.index",[205,207,211,215,219,223,227],{"title":206,"path":202,"stem":203},"Los arreglos en Java",{"title":208,"path":209,"stem":210},"Los arreglos","\u002Farreglos\u002Farray","6.arreglos\u002F02.array",{"title":212,"path":213,"stem":214},"Matrices","\u002Farreglos\u002Fmatrices","6.arreglos\u002F03.matrices",{"title":216,"path":217,"stem":218},"Comparadores","\u002Farreglos\u002Fcomparator","6.arreglos\u002F04.comparator",{"title":220,"path":221,"stem":222},"Arreglos dinámicos: ArrayList","\u002Farreglos\u002Farraylist","6.arreglos\u002F05.arraylist",{"title":224,"path":225,"stem":226},"Arreglos Relacionales: HashMap","\u002Farreglos\u002Fhashmap","6.arreglos\u002F06.hashmap",{"title":228,"path":229,"stem":230},"La clase Stream en Java","\u002Farreglos\u002Fstream","6.arreglos\u002F07.stream",{"title":232,"icon":199,"path":233,"stem":234,"children":235,"page":42},"Archivos e Interfaz de Usuario","\u002Farchivos-ui","7.archivos-ui",[236,240,244,248,252,256,260,264,268,272,276,280,284,288,292,296,300,304,308,312,316],{"title":237,"path":238,"stem":239},"El paquete Swing","\u002Farchivos-ui\u002Fswing","7.archivos-ui\u002F01.swing",{"title":241,"path":242,"stem":243},"La clase JFrame y el JPanel","\u002Farchivos-ui\u002Fjpanel","7.archivos-ui\u002F02.jpanel",{"title":245,"path":246,"stem":247},"Los Layouts en Swing","\u002Farchivos-ui\u002Flayout","7.archivos-ui\u002F03.layout",{"title":249,"path":250,"stem":251},"Iniciando con Swing","\u002Farchivos-ui\u002Finiciando","7.archivos-ui\u002F04.iniciando",{"title":253,"path":254,"stem":255},"Las clases Color y Font en Swing","\u002Farchivos-ui\u002Fcolor-font","7.archivos-ui\u002F05.color-font",{"title":257,"path":258,"stem":259},"Etiquetas en Swing","\u002Farchivos-ui\u002Fetiquetas","7.archivos-ui\u002F06.etiquetas",{"title":261,"path":262,"stem":263},"Personalizando la apariencia de los componentes en Swing","\u002Farchivos-ui\u002Fpersonalizando","7.archivos-ui\u002F07.personalizando",{"title":265,"path":266,"stem":267},"Sobrescribiendo el método drawComponent() en Swing","\u002Farchivos-ui\u002Fdraw","7.archivos-ui\u002F08.draw",{"title":269,"path":270,"stem":271},"Manejando eventos en Swing","\u002Farchivos-ui\u002Feventos","7.archivos-ui\u002F09.eventos",{"title":273,"path":274,"stem":275},"Personalización de Componentes mediante la Extensión de Clases en Swing","\u002Farchivos-ui\u002Fextends-component","7.archivos-ui\u002F10.extends-component",{"title":277,"path":278,"stem":279},"Gradientes","\u002Farchivos-ui\u002Fgradientes","7.archivos-ui\u002F11.gradientes",{"title":281,"path":282,"stem":283},"Botones en Swing","\u002Farchivos-ui\u002Fbotones","7.archivos-ui\u002F12.botones",{"title":285,"path":286,"stem":287},"Los delegadores en Swing","\u002Farchivos-ui\u002Fdelegadores","7.archivos-ui\u002F13.delegadores",{"title":289,"path":290,"stem":291},"UI para nuestro RPG: Parte 1","\u002Farchivos-ui\u002Frpg-ui-1","7.archivos-ui\u002F14.rpg-ui-1",{"title":293,"path":294,"stem":295},"UI para nuestro RPG: Parte 2","\u002Farchivos-ui\u002Frpg-ui-2","7.archivos-ui\u002F15.rpg-ui-2",{"title":297,"path":298,"stem":299},"Los Streams Entrada y Salida","\u002Farchivos-ui\u002Fstreams","7.archivos-ui\u002F16.streams",{"title":301,"path":302,"stem":303},"Archivo tipo Objeto","\u002Farchivos-ui\u002Farchivo-objeto","7.archivos-ui\u002F17.archivo-objeto",{"title":305,"path":306,"stem":307},"UI para nuestro RPG: Parte 3","\u002Farchivos-ui\u002Frpg-ui-3","7.archivos-ui\u002F18.rpg-ui-3",{"title":309,"path":310,"stem":311},"UI para nuestro RPG: Parte 4","\u002Farchivos-ui\u002Frpg-ui-4","7.archivos-ui\u002F19.rpg-ui-4",{"title":313,"path":314,"stem":315},"UI para nuestro RPG: Parte 5","\u002Farchivos-ui\u002Frpg-ui-5","7.archivos-ui\u002F20.rpg-ui-5",{"title":317,"path":318,"stem":319},"UI para nuestro RPG: Parte 6","\u002Farchivos-ui\u002Frpg-ui-6","7.archivos-ui\u002F21.rpg-ui-6",{"title":321,"icon":322,"path":323,"stem":324,"children":325,"page":42},"Ejemplos","i-check-circle","\u002Fejemplos","8.ejemplos",[326,330,334,338,342],{"title":327,"path":328,"stem":329,"icon":105},"Ejemplo 1: Validando entradas con JOptionPane","\u002Fejemplos\u002Fejemplo-01","8.ejemplos\u002F01.ejemplo-01",{"title":331,"path":332,"stem":333},"Ejemplo 02: Uso de clases genéricas en Java","\u002Fejemplos\u002Fejemplo-02","8.ejemplos\u002F02.ejemplo-02",{"title":335,"path":336,"stem":337},"Ejemplo 03: Uso de Enum, Excepciones en Java","\u002Fejemplos\u002Fejemplo-03","8.ejemplos\u002F03.ejemplo-03",{"title":339,"path":340,"stem":341},"Ejemplo 4: Clase con funciones genéricas de validación","\u002Fejemplos\u002Fejemplo-04","8.ejemplos\u002F04.ejemplo-04",{"title":343,"path":344,"stem":345},"Ejemplo 5: Sistema de Gestión de Empleados","\u002Fejemplos\u002Fejemplo-05","8.ejemplos\u002F05.ejemplo-05",{"title":347,"icon":322,"path":348,"stem":349,"children":350,"page":42},"Actividades","\u002Factividades","9.actividades",[351,355,360,364,368,372,376,380,384,388,392,396,400,404,408],{"title":352,"path":353,"stem":354,"icon":105},"Actividad 1: Infografía sobre el proceso de compilación","\u002Factividades\u002Fact-01","9.actividades\u002F01.act-01",{"title":356,"path":357,"stem":358,"icon":359},"Actividad 2: Modelando Diagramas de Clases UML","\u002Factividades\u002Fact-02","9.actividades\u002F02.act-02","i-material-icon-theme-uml",{"title":361,"path":362,"stem":363,"icon":45},"Actividad 3: Creando Clases y Objetos en Java","\u002Factividades\u002Fact-03","9.actividades\u002F03.act-03",{"title":365,"path":366,"stem":367},"Actividad 4: Validando entradas de datos","\u002Factividades\u002Fact-04","9.actividades\u002F04.act-04",{"title":369,"path":370,"stem":371,"icon":105},"Actividad 5: Implementando una clase genérica","\u002Factividades\u002Fact-05","9.actividades\u002F05.act-05",{"title":373,"path":374,"stem":375,"icon":105},"Actividad 6: Expandiendo InputValidator con Predicados y Function","\u002Factividades\u002Fact-06","9.actividades\u002F06.act-06",{"title":377,"path":378,"stem":379,"icon":105},"Actividad 7: Gestor de Biblioteca con InputValidator","\u002Factividades\u002Fact-07","9.actividades\u002F07.act-07",{"title":381,"path":382,"stem":383,"icon":105},"Actividad 8: Calculadora de Figuras Geométricas","\u002Factividades\u002Fact-08","9.actividades\u002F08.act-08",{"title":385,"path":386,"stem":387,"icon":105},"Actividad 9: gestión de una empresa agroalimentaria","\u002Factividades\u002Fact-09","9.actividades\u002F09.act-09",{"title":389,"path":390,"stem":391,"icon":105},"Actividad 10: Sistema de gestión de clínicas veterinarias","\u002Factividades\u002Fact-10","9.actividades\u002F10.act-10",{"title":393,"path":394,"stem":395},"Definición de Proyecto Evolutivo","\u002Factividades\u002Frpg","9.actividades\u002F11.rpg",{"title":397,"path":398,"stem":399},"Actividad 11: Creación de Personajes","\u002Factividades\u002Fact-11","9.actividades\u002F12.act-11",{"title":401,"path":402,"stem":403},"Actividad 12: El Inventario y los Objetos","\u002Factividades\u002Fact-12","9.actividades\u002F13.act-12",{"title":405,"path":406,"stem":407},"Actividad 13: El combate por turnos","\u002Factividades\u002Fact-13","9.actividades\u002F14.act-13",{"title":409,"path":410,"stem":411},"Actividad 14: Guardando y Cargando","\u002Factividades\u002Fact-14","9.actividades\u002F15.act-14",{"id":413,"title":141,"body":414,"description":771,"extension":772,"links":773,"meta":774,"navigation":775,"path":142,"seo":776,"stem":143,"__hash__":777},"docs\u002F4.metodos\u002F05.recursividad.md",{"type":415,"value":416,"toc":763},"minimark",[417,422,426,430,433,450,454,465,468,472,483,599,613,617,620,736,752,756,759],[418,419,421],"h2",{"id":420},"qué-es-la-recursividad","¿Qué es la recursividad?",[423,424,425],"p",{},"La recursividad es una técnica de programación en la que una función se llama a sí misma para resolver un problema. En lugar de utilizar bucles o iteraciones, la recursividad permite que una función se divida en subproblemas más pequeños y manejables, lo que puede simplificar el código y hacerlo más fácil de entender.",[418,427,429],{"id":428},"cómo-funciona-la-recursividad","Cómo funciona la recursividad",[423,431,432],{},"Una función recursiva generalmente consta de dos partes:",[434,435,436,444],"ol",{},[437,438,439,443],"li",{},[440,441,442],"strong",{},"Caso base",": Es la condición que detiene la recursión. Sin un caso base, la función se llamaría a sí misma indefinidamente, lo que resultaría en un error de desbordamiento de pila.",[437,445,446,449],{},[440,447,448],{},"Caso recursivo",": Es la parte de la función que se llama a sí misma con un conjunto de parámetros modificados, acercándose al caso base.",[418,451,453],{"id":452},"preguntas-para-saber-si-un-problema-es-adecuado-para-la-recursividad","Preguntas para saber si un problema es adecuado para la recursividad",[434,455,456,459,462],{},[437,457,458],{},"¿El problema se puede dividir en subproblemas más pequeños del mismo tipo?",[437,460,461],{},"¿Existe un caso base que detenga la recursión?",[437,463,464],{},"¿La solución recursiva es más fácil de entender o implementar que una solución iterativa?",[423,466,467],{},"Si logras responder \"sí\" a estas preguntas, es probable que la recursividad sea una buena opción para resolver el problema.",[418,469,471],{"id":470},"ejemplo-de-recursividad-factorial","Ejemplo de recursividad: Factorial",[423,473,474,475,479,480,482],{},"El factorial de un número entero positivo ",[476,477,478],"code",{},"n"," se define como el producto de todos los enteros desde 1 hasta ",[476,481,478],{},". La función factorial se puede implementar de manera recursiva de la siguiente manera:",[484,485,490],"pre",{"className":486,"code":487,"language":488,"meta":489,"style":489},"language-java shiki shiki-themes github-dark","public int factorial(int n) {\n    \u002F\u002F Caso base: el factorial de 0 es 1\n    if (n == 0) {\n        return 1;\n    }\n    \u002F\u002F Caso recursivo: n! = n * (n - 1)!\n    return n * factorial(n - 1);\n}\n","java","",[476,491,492,518,525,544,556,562,568,593],{"__ignoreMap":489},[493,494,497,501,504,508,512,515],"span",{"class":495,"line":496},"line",1,[493,498,500],{"class":499},"snl16","public",[493,502,503],{"class":499}," int",[493,505,507],{"class":506},"svObZ"," factorial",[493,509,511],{"class":510},"s95oV","(",[493,513,514],{"class":499},"int",[493,516,517],{"class":510}," n) {\n",[493,519,521],{"class":495,"line":520},2,[493,522,524],{"class":523},"sAwPA","    \u002F\u002F Caso base: el factorial de 0 es 1\n",[493,526,528,531,534,537,541],{"class":495,"line":527},3,[493,529,530],{"class":499},"    if",[493,532,533],{"class":510}," (n ",[493,535,536],{"class":499},"==",[493,538,540],{"class":539},"sDLfK"," 0",[493,542,543],{"class":510},") {\n",[493,545,547,550,553],{"class":495,"line":546},4,[493,548,549],{"class":499},"        return",[493,551,552],{"class":539}," 1",[493,554,555],{"class":510},";\n",[493,557,559],{"class":495,"line":558},5,[493,560,561],{"class":510},"    }\n",[493,563,565],{"class":495,"line":564},6,[493,566,567],{"class":523},"    \u002F\u002F Caso recursivo: n! = n * (n - 1)!\n",[493,569,571,574,577,580,582,585,588,590],{"class":495,"line":570},7,[493,572,573],{"class":499},"    return",[493,575,576],{"class":510}," n ",[493,578,579],{"class":499},"*",[493,581,507],{"class":506},[493,583,584],{"class":510},"(n ",[493,586,587],{"class":499},"-",[493,589,552],{"class":539},[493,591,592],{"class":510},");\n",[493,594,596],{"class":495,"line":595},8,[493,597,598],{"class":510},"}\n",[423,600,601,602,604,605,608,609,612],{},"En este ejemplo, el caso base es cuando ",[476,603,478],{}," es igual a 0, donde el factorial de 0 es 1. El caso recursivo se define como ",[476,606,607],{},"n! = n * (n - 1)!",", lo que significa que la función se llama a sí misma con ",[476,610,611],{},"n - 1"," hasta llegar al caso base.",[418,614,616],{"id":615},"ejemplo-de-recursividad-fibonacci","Ejemplo de recursividad: Fibonacci",[423,618,619],{},"La secuencia de Fibonacci es una serie de números donde cada número es la suma de los dos anteriores. La función para calcular el n-ésimo número de Fibonacci se puede implementar de manera recursiva de la siguiente manera:",[484,621,623],{"className":486,"code":622,"language":488,"meta":489,"style":489},"public int fibonacci(int n) {\n    \u002F\u002F Casos base: F(0) = 0, F(1) = 1\n    if (n == 0) {\n        return 0;\n    } else if (n == 1) {\n        return 1;\n    }\n    \u002F\u002F Caso recursivo: F(n) = F(n - 1) + F(n - 2)\n    return fibonacci(n - 1) + fibonacci(n - 2);\n}\n",[476,624,625,640,645,657,665,684,692,696,701,731],{"__ignoreMap":489},[493,626,627,629,631,634,636,638],{"class":495,"line":496},[493,628,500],{"class":499},[493,630,503],{"class":499},[493,632,633],{"class":506}," fibonacci",[493,635,511],{"class":510},[493,637,514],{"class":499},[493,639,517],{"class":510},[493,641,642],{"class":495,"line":520},[493,643,644],{"class":523},"    \u002F\u002F Casos base: F(0) = 0, F(1) = 1\n",[493,646,647,649,651,653,655],{"class":495,"line":527},[493,648,530],{"class":499},[493,650,533],{"class":510},[493,652,536],{"class":499},[493,654,540],{"class":539},[493,656,543],{"class":510},[493,658,659,661,663],{"class":495,"line":546},[493,660,549],{"class":499},[493,662,540],{"class":539},[493,664,555],{"class":510},[493,666,667,670,673,676,678,680,682],{"class":495,"line":558},[493,668,669],{"class":510},"    } ",[493,671,672],{"class":499},"else",[493,674,675],{"class":499}," if",[493,677,533],{"class":510},[493,679,536],{"class":499},[493,681,552],{"class":539},[493,683,543],{"class":510},[493,685,686,688,690],{"class":495,"line":564},[493,687,549],{"class":499},[493,689,552],{"class":539},[493,691,555],{"class":510},[493,693,694],{"class":495,"line":570},[493,695,561],{"class":510},[493,697,698],{"class":495,"line":595},[493,699,700],{"class":523},"    \u002F\u002F Caso recursivo: F(n) = F(n - 1) + F(n - 2)\n",[493,702,704,706,708,710,712,714,717,720,722,724,726,729],{"class":495,"line":703},9,[493,705,573],{"class":499},[493,707,633],{"class":506},[493,709,584],{"class":510},[493,711,587],{"class":499},[493,713,552],{"class":539},[493,715,716],{"class":510},") ",[493,718,719],{"class":499},"+",[493,721,633],{"class":506},[493,723,584],{"class":510},[493,725,587],{"class":499},[493,727,728],{"class":539}," 2",[493,730,592],{"class":510},[493,732,734],{"class":495,"line":733},10,[493,735,598],{"class":510},[423,737,738,739,741,742,608,745,747,748,751],{},"En este ejemplo, los casos base son cuando ",[476,740,478],{}," es igual a 0 o 1, donde el número de Fibonacci es 0 y 1 respectivamente. El caso recursivo se define como ",[476,743,744],{},"F(n) = F(n - 1) + F(n - 2)",[476,746,611],{}," y ",[476,749,750],{},"n - 2"," hasta llegar a los casos base.",[418,753,755],{"id":754},"conclusión","Conclusión",[423,757,758],{},"La recursividad es una técnica poderosa en programación que permite resolver problemas de manera elegante y eficiente. Al comprender cómo funciona la recursividad y cuándo es apropiada, puedes escribir código más limpio y fácil de entender. Sin embargo, es importante tener cuidado al usar la recursividad, ya que un caso base mal definido o una recursión infinita pueden llevar a errores de desbordamiento de pila.",[760,761,762],"style",{},"html pre.shiki code .snl16, html code.shiki .snl16{--shiki-default:#F97583}html pre.shiki code .svObZ, html code.shiki .svObZ{--shiki-default:#B392F0}html pre.shiki code .s95oV, html code.shiki .s95oV{--shiki-default:#E1E4E8}html pre.shiki code .sAwPA, html code.shiki .sAwPA{--shiki-default:#6A737D}html pre.shiki code .sDLfK, html code.shiki .sDLfK{--shiki-default:#79B8FF}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}",{"title":489,"searchDepth":520,"depth":520,"links":764},[765,766,767,768,769,770],{"id":420,"depth":520,"text":421},{"id":428,"depth":520,"text":429},{"id":452,"depth":520,"text":453},{"id":470,"depth":520,"text":471},{"id":615,"depth":520,"text":616},{"id":754,"depth":520,"text":755},"En este artículo, se explica el concepto de recursividad en programación, cómo funciona, y se presentan ejemplos de cómo utilizar la recursividad para resolver problemas de manera eficiente.","md",null,{"editButton":42},true,{"title":141,"description":771},"3Q01ZnF27F1d0lek7uV_4cc1blv_VX2wjqSunaOAu9s",[779,781],{"title":137,"path":138,"stem":139,"description":780,"children":-1},"En este artículo, se explica el concepto de alcance en programación, cómo afecta a las variables y métodos, y cómo se pueden utilizar diferentes niveles de alcance para controlar la visibilidad y el acceso a los elementos de un programa.",{"title":145,"path":146,"stem":147,"description":782,"children":-1},"En este artículo, se explica el concepto de puntero `this` en programación orientada a objetos, cómo se utiliza para referirse al objeto actual dentro de una clase, y se presentan ejemplos de cómo utilizar `this` para acceder a variables y métodos de la clase, así como para resolver conflictos de nombres y mejorar la legibilidad del código.",1779479569174]