SlideShare una empresa de Scribd logo
1 de 16
Descargar para leer sin conexión
Funciones y Recursividad
Ramiro Estigarribia Canese
Programas Reales
➔ La mayoría de los programas que resuelven
problemas reales son más grandes que los
programas que se presentan en los primeros
capítulos.
➔ La experiencia ha demostrado que la mejor forma
de desarrollar y mantener un programa extenso es
construirlo a partir de piezas (o componentes)
simples y pequeñas.
➔ A esta técnica se le conoce como divide y
vencerás.
Componentes de los
programas en C++
➔ Por lo general, los programas en C++ se escriben
mediante la combinación de nuevas funciones y
clases que escribimos con funciones disponibles en
C++.
➔ La Biblioteca estándar de C++ proporciona una
extensa colección de funciones para realizar
cálculos matemáticos, manipulación de texto,
entrada/salida, comprobación de errores y otras
operaciones.
➔ Esto facilita el trabajo del programador, ya que
estas funciones proporcionan muchas de las
herramientas que necesita.
¿Qué Permiten
las Funciones?
➔ Las funciones permiten dividir un programa en
módulos.
➔ Las instrucciones se escriben sólo una vez, y se
pueden reutilizar muchas veces.
➔ Se facilita el proceso de desarrollo de programas al
construir a partir de piezas pequeñas y simples.
➔ Permite reutilización de software: utilizar las
funciones existentes como bloques de construcción
para crear nuevos programas.
Funciones matemáticas de
la biblioteca
➔ Utilizamos la función pow del archivo de
encabezado <cmath> para elevar un valor a una
potencia.
➔ Introduciremos aquí varias funciones del archivo de
encabezado <cmath> para presentar el concepto
de las funciones globales que no pertenecen a una
clase específica.
➔ El archivo de encabezado <cmath> proporciona
una colección de funciones que nos permiten
realizar cálculos matemáticos comunes.
➔ Por ejemplo, puede calcular la raíz cuadrada de
900.0 con la siguiente llamada a la función:
La clase Math
➔ La clase Math cuenta con una colección de
métodos que nos permiten realizar cálculos
matemáticos.
➔ Por ejemplo, podemos calcular la raíz cuadrada de
900 con una llamada al siguiente método:
sqrt(900). Resultado = 30.0.
➔ El método sqrt recibe un argumento de tipo double
y devuelve el resultado.
➔ Para imprimir el valor de la llamada anterior al
método en una ventana de comandos:
➔ cout << sqrt(900);
1.Raiz Cuadrada
#include <iostream>
#include <math.h>
using namespace std;
int main()
{
int numero, raiz;
cout << "Ingrese 1 numero" << endl;
cin >> numero;
raiz=sqrt(numero);
cout << "La raiz es:" << raiz;
return 0;
}
Funciones con varios
Parámetros
//2.Función que calcula el cuadrado de un número.
#include <iostream>
using namespace std;
int cuadrado(int numero)
{ return numero*numero; }
int main()
{
int numero,resultado;
cout << "Ingrese 1 numero" << endl;
cin >> numero;
resultado=cuadrado(numero);
cout << "El cuadrado es:" << resultado;
return 0;
}
¿Qué es una Función?
➔ Es un conjunto de líneas de código que realizan
una tarea específica y puede retornar un valor.
➔ Las funciones pueden tomar parámetros que
modifiquen su funcionamiento.
➔ Las funciones son utilizadas para descomponer
grandes problemas en tareas simples.
➔ Cuando una función es invocada se le pasa el
control a la misma, una vez que esta finalizó con su
tarea el control es devuelto al punto desde el cual
la función fue llamada.
Random
➔ Se puede crear un generador de números
aleatorios de la siguiente manera:
sorteo = rand( );
➔ Después, el generador de números aleatorios
puede usarse para generar valores boolean, byte,
float, double, int, long y gaussianos.
➔ El método nextInt de la clase Random genera un
valor int aleatorio en el rango de –2.147.483.648 a
+2.147.483.647.
➔ Cualquier valor en ese rango debería tener una
oportunidad de salir sorteado.
3.Programa que lanza un
dado 5 veces
#include <iostream>
#include <cstdlib> // Función para rand
using namespace std;
int main()
{
for (int contador=1; contador<=5; contador++)
{
cout << (1 + rand()%6 ) << " "; //muestra el valor generado
} // fin de for
return 0;
}
//4.Sortea un número, y compara con el valor ingresado.
#include <iostream>
#include <cstdlib> // Función para rand
#include <ctime> // Función para tiempo
using namespace std;
int main()
{
srand(time(0)); //Para que el sorteo distinto siempre.
int numero, resultado;
cout << "Elija un número del 1 al 6:" << endl;
cin >> numero;
resultado=1+rand()%6;
if (numero==resultado)
cout << "Felicitaciones, ganaste" << endl;
else
cout << "Lastimosamente perdiste: " << resultado;
return 0;
}
Recursividad
➔ Los programas que hemos visto están
estructurados generalmente como funciones que se
llaman entre sí, de una manera disciplinada y
jerárquica.
➔ Para algunos problemas, es conveniente hacer que
las funciones se llamen a sí mismas.
➔ Una función recursiva es una función que se llama
a sí misma.
5.Factorial de un número.
#include <iostream>
using namespace std;
int main()
{
int num=3,fact=1;
for(int i=1; i<=num; i++)
{
fact = fact * i;
}
cout << "Su factorial es: " << fact;
return 0;
}
//6.Factorial utilizando un método recursivo.
#include <iostream>
using namespace std;
int factorial(int n)
{
if(n<2)
return 1;
else
return n*factorial(n-1);
}
int main()
{
int numero;
cout << "Introduce un numero:" << endl;
cin >> numero;
cout << "El resultado es:" << factorial(numero);
return 0;
}

Más contenido relacionado

La actualidad más candente

Estructura de lenguaje ensamblador
Estructura de lenguaje ensambladorEstructura de lenguaje ensamblador
Estructura de lenguaje ensambladorEustakiu Padilla
 
Algoritmos 50 ejemplos (1)
Algoritmos 50 ejemplos (1)Algoritmos 50 ejemplos (1)
Algoritmos 50 ejemplos (1)Andres Rivero
 
POO. Unidad 2: Clases y objetos Ejercicio 2
POO. Unidad 2: Clases y objetos Ejercicio 2POO. Unidad 2: Clases y objetos Ejercicio 2
POO. Unidad 2: Clases y objetos Ejercicio 2Fabiola Valerio Ramirez
 
Programación modular en Introducción a la Programación
Programación modular en Introducción a la ProgramaciónProgramación modular en Introducción a la Programación
Programación modular en Introducción a la ProgramaciónFacultad de Ciencias y Sistemas
 
INSTRUCCIONES BÁSICAS PARA C++
INSTRUCCIONES BÁSICAS PARA C++INSTRUCCIONES BÁSICAS PARA C++
INSTRUCCIONES BÁSICAS PARA C++Idalia Tristan
 
Redondear un número entero ingresado a la decena y centena más cercana.
Redondear un número entero ingresado a la decena y centena más cercana. Redondear un número entero ingresado a la decena y centena más cercana.
Redondear un número entero ingresado a la decena y centena más cercana. Carlos Aviles Galeas
 
Parte 4 Máquinas De Turing
Parte 4  Máquinas De  TuringParte 4  Máquinas De  Turing
Parte 4 Máquinas De TuringRicardo Quintero
 
Ejercicios resueltos de programacion
Ejercicios resueltos de programacionEjercicios resueltos de programacion
Ejercicios resueltos de programacionJaime amambal
 
Listas de adyacencia
Listas de adyacenciaListas de adyacencia
Listas de adyacencialeidy2220
 
Ejercicios programacion prolog
Ejercicios programacion prologEjercicios programacion prolog
Ejercicios programacion prologrogersgarcia
 
Metodos de-ordenamiento
Metodos de-ordenamientoMetodos de-ordenamiento
Metodos de-ordenamientodeff000001
 
Pasos para la construcción de una máquina de turing
Pasos para la construcción de una máquina de turingPasos para la construcción de una máquina de turing
Pasos para la construcción de una máquina de turingJonathan Bastidas
 
52 ejercicios resueltos en pseudocodigo
52 ejercicios resueltos en pseudocodigo52 ejercicios resueltos en pseudocodigo
52 ejercicios resueltos en pseudocodigoBrivé Soluciones
 

La actualidad más candente (20)

Estructura de lenguaje ensamblador
Estructura de lenguaje ensambladorEstructura de lenguaje ensamblador
Estructura de lenguaje ensamblador
 
Algoritmos 50 ejemplos (1)
Algoritmos 50 ejemplos (1)Algoritmos 50 ejemplos (1)
Algoritmos 50 ejemplos (1)
 
Ejercicios de qbasic
Ejercicios de qbasicEjercicios de qbasic
Ejercicios de qbasic
 
POO. Unidad 2: Clases y objetos Ejercicio 2
POO. Unidad 2: Clases y objetos Ejercicio 2POO. Unidad 2: Clases y objetos Ejercicio 2
POO. Unidad 2: Clases y objetos Ejercicio 2
 
Programación modular en Introducción a la Programación
Programación modular en Introducción a la ProgramaciónProgramación modular en Introducción a la Programación
Programación modular en Introducción a la Programación
 
INSTRUCCIONES BÁSICAS PARA C++
INSTRUCCIONES BÁSICAS PARA C++INSTRUCCIONES BÁSICAS PARA C++
INSTRUCCIONES BÁSICAS PARA C++
 
Redondear un número entero ingresado a la decena y centena más cercana.
Redondear un número entero ingresado a la decena y centena más cercana. Redondear un número entero ingresado a la decena y centena más cercana.
Redondear un número entero ingresado a la decena y centena más cercana.
 
Parte 4 Máquinas De Turing
Parte 4  Máquinas De  TuringParte 4  Máquinas De  Turing
Parte 4 Máquinas De Turing
 
Ejercicios resueltos de programacion
Ejercicios resueltos de programacionEjercicios resueltos de programacion
Ejercicios resueltos de programacion
 
Expresiones regulares
Expresiones regularesExpresiones regulares
Expresiones regulares
 
Listas de adyacencia
Listas de adyacenciaListas de adyacencia
Listas de adyacencia
 
Ejercicios programacion prolog
Ejercicios programacion prologEjercicios programacion prolog
Ejercicios programacion prolog
 
Algoritmos
AlgoritmosAlgoritmos
Algoritmos
 
Algoritmo
Algoritmo Algoritmo
Algoritmo
 
Metodos de-ordenamiento
Metodos de-ordenamientoMetodos de-ordenamiento
Metodos de-ordenamiento
 
Pasos para la construcción de una máquina de turing
Pasos para la construcción de una máquina de turingPasos para la construcción de una máquina de turing
Pasos para la construcción de una máquina de turing
 
Algoritmos 50 ejemplos
Algoritmos 50 ejemplosAlgoritmos 50 ejemplos
Algoritmos 50 ejemplos
 
52 ejercicios resueltos en pseudocodigo
52 ejercicios resueltos en pseudocodigo52 ejercicios resueltos en pseudocodigo
52 ejercicios resueltos en pseudocodigo
 
Arreglos
ArreglosArreglos
Arreglos
 
Programación - Matrices
Programación - Matrices Programación - Matrices
Programación - Matrices
 

Destacado

RECURSIVIDAD C++
RECURSIVIDAD C++RECURSIVIDAD C++
RECURSIVIDAD C++Ing SC B
 
Recursividad
RecursividadRecursividad
Recursividadbetzy
 
Estructura de Datos: Recursividad
Estructura de Datos: RecursividadEstructura de Datos: Recursividad
Estructura de Datos: RecursividadYanahui Bc
 
Unidad 4 est. dat. recursividad
Unidad 4  est. dat. recursividadUnidad 4  est. dat. recursividad
Unidad 4 est. dat. recursividadrehoscript
 
R E L A C I O N E S D E R E C U R R E N C I A
R E L A C I O N E S  D E  R E C U R R E N C I AR E L A C I O N E S  D E  R E C U R R E N C I A
R E L A C I O N E S D E R E C U R R E N C I Ajhonricardo
 
Cómo podemos entender la ciencia yoisy
Cómo podemos entender la ciencia yoisyCómo podemos entender la ciencia yoisy
Cómo podemos entender la ciencia yoisyyoisysanchezmiranda
 
7.modelado de los requerimientos escenarios y clases
7.modelado de los requerimientos  escenarios y clases7.modelado de los requerimientos  escenarios y clases
7.modelado de los requerimientos escenarios y clasesRamiro Estigarribia Canese
 
Algoritmos recursivos
Algoritmos recursivosAlgoritmos recursivos
Algoritmos recursivosfeytho
 
Programación Modular
Programación ModularProgramación Modular
Programación Modularguestefc95b
 
Metodología de la Investigación - Unidad 3 (Parte 1)
Metodología de la Investigación - Unidad 3 (Parte 1)Metodología de la Investigación - Unidad 3 (Parte 1)
Metodología de la Investigación - Unidad 3 (Parte 1)Ricardo Cuberos Mejía
 
PROGRAMAS EN DEV C++
PROGRAMAS EN DEV C++PROGRAMAS EN DEV C++
PROGRAMAS EN DEV C++KarenAlmanza
 
Programación Modular y Estructyrada
Programación Modular y EstructyradaProgramación Modular y Estructyrada
Programación Modular y Estructyradaguestefc95b
 
EL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADO
EL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADOEL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADO
EL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADOCARLOS MASSUH
 

Destacado (20)

RECURSIVIDAD C++
RECURSIVIDAD C++RECURSIVIDAD C++
RECURSIVIDAD C++
 
Recursividad
RecursividadRecursividad
Recursividad
 
Recursividad
RecursividadRecursividad
Recursividad
 
Estructura de Datos: Recursividad
Estructura de Datos: RecursividadEstructura de Datos: Recursividad
Estructura de Datos: Recursividad
 
Unidad 4 est. dat. recursividad
Unidad 4  est. dat. recursividadUnidad 4  est. dat. recursividad
Unidad 4 est. dat. recursividad
 
Catalan
CatalanCatalan
Catalan
 
R E L A C I O N E S D E R E C U R R E N C I A
R E L A C I O N E S  D E  R E C U R R E N C I AR E L A C I O N E S  D E  R E C U R R E N C I A
R E L A C I O N E S D E R E C U R R E N C I A
 
Algoritmos recursivos
Algoritmos recursivosAlgoritmos recursivos
Algoritmos recursivos
 
Cómo podemos entender la ciencia yoisy
Cómo podemos entender la ciencia yoisyCómo podemos entender la ciencia yoisy
Cómo podemos entender la ciencia yoisy
 
Unidad 4, investigacion
Unidad 4, investigacionUnidad 4, investigacion
Unidad 4, investigacion
 
7.modelado de los requerimientos escenarios y clases
7.modelado de los requerimientos  escenarios y clases7.modelado de los requerimientos  escenarios y clases
7.modelado de los requerimientos escenarios y clases
 
Algoritmos recursivos
Algoritmos recursivosAlgoritmos recursivos
Algoritmos recursivos
 
Programación Modular
Programación ModularProgramación Modular
Programación Modular
 
2.1 recursividad
2.1 recursividad2.1 recursividad
2.1 recursividad
 
Metodología de la Investigación - Unidad 3 (Parte 1)
Metodología de la Investigación - Unidad 3 (Parte 1)Metodología de la Investigación - Unidad 3 (Parte 1)
Metodología de la Investigación - Unidad 3 (Parte 1)
 
Programación modular
Programación modularProgramación modular
Programación modular
 
PROGRAMAS EN DEV C++
PROGRAMAS EN DEV C++PROGRAMAS EN DEV C++
PROGRAMAS EN DEV C++
 
Programacion Modular
Programacion ModularProgramacion Modular
Programacion Modular
 
Programación Modular y Estructyrada
Programación Modular y EstructyradaProgramación Modular y Estructyrada
Programación Modular y Estructyrada
 
EL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADO
EL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADOEL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADO
EL PROBLEMA DE INVESTIGACIÓN DE LA TESIS DE GRADO
 

Similar a 6.funciones y recursividad en c++

Similar a 6.funciones y recursividad en c++ (20)

Manual.es
Manual.esManual.es
Manual.es
 
Lenguaje c neo
Lenguaje c neoLenguaje c neo
Lenguaje c neo
 
Cesar lenguaje c_
Cesar lenguaje c_Cesar lenguaje c_
Cesar lenguaje c_
 
Intro2
Intro2Intro2
Intro2
 
Conociendo los Lenguajes de Programacion
Conociendo los Lenguajes de ProgramacionConociendo los Lenguajes de Programacion
Conociendo los Lenguajes de Programacion
 
Algoritmos - Funciones C++
Algoritmos - Funciones C++ Algoritmos - Funciones C++
Algoritmos - Funciones C++
 
Eficiencia en uso en algoritmos- tiempo de ejecución
Eficiencia en uso en algoritmos- tiempo de ejecuciónEficiencia en uso en algoritmos- tiempo de ejecución
Eficiencia en uso en algoritmos- tiempo de ejecución
 
Ejercicios de programacion if - switch-case
Ejercicios de programacion   if  -   switch-caseEjercicios de programacion   if  -   switch-case
Ejercicios de programacion if - switch-case
 
Ejemplos Para Dev C++
Ejemplos Para Dev C++Ejemplos Para Dev C++
Ejemplos Para Dev C++
 
De algoritmo a programa en c++
De algoritmo a programa en c++De algoritmo a programa en c++
De algoritmo a programa en c++
 
Algoritmos para c#
Algoritmos para c#Algoritmos para c#
Algoritmos para c#
 
5.instrucciones de control en c++ parte 2
5.instrucciones de control en c++  parte 25.instrucciones de control en c++  parte 2
5.instrucciones de control en c++ parte 2
 
6.Métodos en Java
6.Métodos en Java6.Métodos en Java
6.Métodos en Java
 
IF-ELSE EN Csharp C#
IF-ELSE EN Csharp C#IF-ELSE EN Csharp C#
IF-ELSE EN Csharp C#
 
07 funciones
07 funciones07 funciones
07 funciones
 
Lenguajec(1)
Lenguajec(1)Lenguajec(1)
Lenguajec(1)
 
Viernes Tecnicos DTrace
Viernes Tecnicos DTraceViernes Tecnicos DTrace
Viernes Tecnicos DTrace
 
Numeros de armstrong en c programacion estructurada
Numeros de armstrong en c programacion estructuradaNumeros de armstrong en c programacion estructurada
Numeros de armstrong en c programacion estructurada
 
2.introducción a las aplicaciones en c++
2.introducción a las aplicaciones en c++2.introducción a las aplicaciones en c++
2.introducción a las aplicaciones en c++
 
Tutorial c++
Tutorial c++Tutorial c++
Tutorial c++
 

Más de Ramiro Estigarribia Canese

8.Flujo, Comportamiento, Patrones y WebApps.pdf
8.Flujo, Comportamiento, Patrones y WebApps.pdf8.Flujo, Comportamiento, Patrones y WebApps.pdf
8.Flujo, Comportamiento, Patrones y WebApps.pdfRamiro Estigarribia Canese
 

Más de Ramiro Estigarribia Canese (20)

8.Flujo, Comportamiento, Patrones y WebApps.pdf
8.Flujo, Comportamiento, Patrones y WebApps.pdf8.Flujo, Comportamiento, Patrones y WebApps.pdf
8.Flujo, Comportamiento, Patrones y WebApps.pdf
 
Principios que Guían la Práctica
Principios que Guían la PrácticaPrincipios que Guían la Práctica
Principios que Guían la Práctica
 
CSS - Hojas de Estilo en Cascada.pdf
CSS -  Hojas de Estilo en Cascada.pdfCSS -  Hojas de Estilo en Cascada.pdf
CSS - Hojas de Estilo en Cascada.pdf
 
Python conceptos básicos
Python   conceptos básicosPython   conceptos básicos
Python conceptos básicos
 
Diseño de WebApps
Diseño de WebAppsDiseño de WebApps
Diseño de WebApps
 
Diseño basado en patrones
Diseño basado en patronesDiseño basado en patrones
Diseño basado en patrones
 
Servicios web
Servicios webServicios web
Servicios web
 
Especificaciones de los procesadores
Especificaciones de los procesadoresEspecificaciones de los procesadores
Especificaciones de los procesadores
 
Lenguaje de programación awk
Lenguaje de programación awkLenguaje de programación awk
Lenguaje de programación awk
 
Bases de datos con PHP y PDO
Bases de datos con PHP y PDOBases de datos con PHP y PDO
Bases de datos con PHP y PDO
 
Bases de datos con PHP y Mysqli
Bases de datos con PHP y MysqliBases de datos con PHP y Mysqli
Bases de datos con PHP y Mysqli
 
Interfaz de usuario
Interfaz de usuarioInterfaz de usuario
Interfaz de usuario
 
Variables del sistema en php
Variables del sistema en phpVariables del sistema en php
Variables del sistema en php
 
Funciones en php
Funciones en phpFunciones en php
Funciones en php
 
Bootstrap menues, contenedores y formularios
Bootstrap   menues, contenedores y formulariosBootstrap   menues, contenedores y formularios
Bootstrap menues, contenedores y formularios
 
Estructuras de control en bash
Estructuras de control en bashEstructuras de control en bash
Estructuras de control en bash
 
Visual studio code
Visual studio codeVisual studio code
Visual studio code
 
Diseño de software
Diseño de softwareDiseño de software
Diseño de software
 
Herramienta cacti
Herramienta cactiHerramienta cacti
Herramienta cacti
 
Monitoreo de datacenter
Monitoreo de datacenterMonitoreo de datacenter
Monitoreo de datacenter
 

Último

How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.FlorenciaCattelani
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...JohnRamos830530
 
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxEVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxJorgeParada26
 
redes informaticas en una oficina administrativa
redes informaticas en una oficina administrativaredes informaticas en una oficina administrativa
redes informaticas en una oficina administrativanicho110
 
Buenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxBuenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxFederico Castellari
 
Guia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos BasicosGuia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos BasicosJhonJairoRodriguezCe
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estossgonzalezp1
 
Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21mariacbr99
 
investigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIinvestigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIhmpuellon
 
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxPROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxAlan779941
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanamcerpam
 

Último (11)

How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
 
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxEVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
 
redes informaticas en una oficina administrativa
redes informaticas en una oficina administrativaredes informaticas en una oficina administrativa
redes informaticas en una oficina administrativa
 
Buenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxBuenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptx
 
Guia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos BasicosGuia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos Basicos
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estos
 
Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21
 
investigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIinvestigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXI
 
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxPROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvana
 

6.funciones y recursividad en c++

  • 1. Funciones y Recursividad Ramiro Estigarribia Canese
  • 2. Programas Reales ➔ La mayoría de los programas que resuelven problemas reales son más grandes que los programas que se presentan en los primeros capítulos. ➔ La experiencia ha demostrado que la mejor forma de desarrollar y mantener un programa extenso es construirlo a partir de piezas (o componentes) simples y pequeñas. ➔ A esta técnica se le conoce como divide y vencerás.
  • 3. Componentes de los programas en C++ ➔ Por lo general, los programas en C++ se escriben mediante la combinación de nuevas funciones y clases que escribimos con funciones disponibles en C++. ➔ La Biblioteca estándar de C++ proporciona una extensa colección de funciones para realizar cálculos matemáticos, manipulación de texto, entrada/salida, comprobación de errores y otras operaciones. ➔ Esto facilita el trabajo del programador, ya que estas funciones proporcionan muchas de las herramientas que necesita.
  • 4. ¿Qué Permiten las Funciones? ➔ Las funciones permiten dividir un programa en módulos. ➔ Las instrucciones se escriben sólo una vez, y se pueden reutilizar muchas veces. ➔ Se facilita el proceso de desarrollo de programas al construir a partir de piezas pequeñas y simples. ➔ Permite reutilización de software: utilizar las funciones existentes como bloques de construcción para crear nuevos programas.
  • 5. Funciones matemáticas de la biblioteca ➔ Utilizamos la función pow del archivo de encabezado <cmath> para elevar un valor a una potencia. ➔ Introduciremos aquí varias funciones del archivo de encabezado <cmath> para presentar el concepto de las funciones globales que no pertenecen a una clase específica. ➔ El archivo de encabezado <cmath> proporciona una colección de funciones que nos permiten realizar cálculos matemáticos comunes. ➔ Por ejemplo, puede calcular la raíz cuadrada de 900.0 con la siguiente llamada a la función:
  • 6. La clase Math ➔ La clase Math cuenta con una colección de métodos que nos permiten realizar cálculos matemáticos. ➔ Por ejemplo, podemos calcular la raíz cuadrada de 900 con una llamada al siguiente método: sqrt(900). Resultado = 30.0. ➔ El método sqrt recibe un argumento de tipo double y devuelve el resultado. ➔ Para imprimir el valor de la llamada anterior al método en una ventana de comandos: ➔ cout << sqrt(900);
  • 7.
  • 8. 1.Raiz Cuadrada #include <iostream> #include <math.h> using namespace std; int main() { int numero, raiz; cout << "Ingrese 1 numero" << endl; cin >> numero; raiz=sqrt(numero); cout << "La raiz es:" << raiz; return 0; }
  • 9. Funciones con varios Parámetros //2.Función que calcula el cuadrado de un número. #include <iostream> using namespace std; int cuadrado(int numero) { return numero*numero; } int main() { int numero,resultado; cout << "Ingrese 1 numero" << endl; cin >> numero; resultado=cuadrado(numero); cout << "El cuadrado es:" << resultado; return 0; }
  • 10. ¿Qué es una Función? ➔ Es un conjunto de líneas de código que realizan una tarea específica y puede retornar un valor. ➔ Las funciones pueden tomar parámetros que modifiquen su funcionamiento. ➔ Las funciones son utilizadas para descomponer grandes problemas en tareas simples. ➔ Cuando una función es invocada se le pasa el control a la misma, una vez que esta finalizó con su tarea el control es devuelto al punto desde el cual la función fue llamada.
  • 11. Random ➔ Se puede crear un generador de números aleatorios de la siguiente manera: sorteo = rand( ); ➔ Después, el generador de números aleatorios puede usarse para generar valores boolean, byte, float, double, int, long y gaussianos. ➔ El método nextInt de la clase Random genera un valor int aleatorio en el rango de –2.147.483.648 a +2.147.483.647. ➔ Cualquier valor en ese rango debería tener una oportunidad de salir sorteado.
  • 12. 3.Programa que lanza un dado 5 veces #include <iostream> #include <cstdlib> // Función para rand using namespace std; int main() { for (int contador=1; contador<=5; contador++) { cout << (1 + rand()%6 ) << " "; //muestra el valor generado } // fin de for return 0; }
  • 13. //4.Sortea un número, y compara con el valor ingresado. #include <iostream> #include <cstdlib> // Función para rand #include <ctime> // Función para tiempo using namespace std; int main() { srand(time(0)); //Para que el sorteo distinto siempre. int numero, resultado; cout << "Elija un número del 1 al 6:" << endl; cin >> numero; resultado=1+rand()%6; if (numero==resultado) cout << "Felicitaciones, ganaste" << endl; else cout << "Lastimosamente perdiste: " << resultado; return 0; }
  • 14. Recursividad ➔ Los programas que hemos visto están estructurados generalmente como funciones que se llaman entre sí, de una manera disciplinada y jerárquica. ➔ Para algunos problemas, es conveniente hacer que las funciones se llamen a sí mismas. ➔ Una función recursiva es una función que se llama a sí misma.
  • 15. 5.Factorial de un número. #include <iostream> using namespace std; int main() { int num=3,fact=1; for(int i=1; i<=num; i++) { fact = fact * i; } cout << "Su factorial es: " << fact; return 0; }
  • 16. //6.Factorial utilizando un método recursivo. #include <iostream> using namespace std; int factorial(int n) { if(n<2) return 1; else return n*factorial(n-1); } int main() { int numero; cout << "Introduce un numero:" << endl; cin >> numero; cout << "El resultado es:" << factorial(numero); return 0; }