SlideShare una empresa de Scribd logo
1 de 22
Iteraciones y decisiones en C++
JUAN JESÚS MENDOZA GONZÁLEZ
JOSÉ ÁNGEL ROSALES GARCÍA
1- Sentencias de decisión
 DEFINICIÓN
 Las sentencias de decisión o también llamadas de
CONTROL DE FLUJO son estructuras de control que
una pregunta la cual retorna verdadero o falso
(evalúa una condición) y selecciona la siguiente
instrucción a ejecutar dependiendo la respuesta o
resultado.
 En algún momento dentro de nuestros algoritmos, es preciso cambiar el flujo de
ejecución de las instrucciones, es decir, el orden en que las instrucciones son
ejecutadas. Muchas de las veces tenemos que tomar una decisión en cuanto a que
se debe ejecutar basándonos en una respuesta de verdadero o falso (condición). La
ejecución de las instrucciones incluyendo una estructura de control como el
condicional funcionan de esta manera:
 Las instrucciones comienzan a ejecutarse de forma secuencial (en orden) y cuando
se llega a una estructura condicional, la cual esta asociada a una condición, se
decide que camino tomar dependiendo siempre del resultado de la condición
siendo esta falsa o verdadera.
 Cuando se termina de ejecutar este bloque de instrucciones se reanuda la ejecución
en la instrucción siguiente a la de la condicional.
Sentencia if
 La instrucción if es, por excelencia, la más utilizada para construir estructuras de control de flujo.
 SINTAXIS
 Primera Forma
 Ahora bién, la sintaxis utilizada en la programación de C++ es la siguiente: if (condicion) { Set de instrucciones }
siendo “condicion” el lugar donde se pondrá la condición que se tiene que cumplir para que sea verdadera
la sentencia y así proceder a realizar el “set de instrucciones” o código contenido dentro de la sentencia.
 Segunda Forma
 Ahora veremos la misma sintaxis pero ahora le añadiremos la parte “Falsa” de la sentencia: if (condicion) { Set
de instrucciones //PARTE VERDADERA } else { Set de instrucciones 2 //Parte FALSA }
 La forma mostrada anteriormente muestra la union de la parte “VERDADERA” con la nueva secuencia la cual
es la parte “FALSA” de la sentencia de decision “IF” en la cual esta compuesta por el: else { Set de
instrucciones 2 //Parte FALSA } la palabra “else” o “De lo contrario” indica al lenguaje que de lo contrario al no
ser verdadera o no se cumpla la parte verdadera entonces realizara el “set de instrucciones 2”.
EJEMPLOS DE SENTENCIAS IF...
 Ejemplo 1:
 if(numero == 0) //La condicion indica que tiene que ser igual a Cero {
cout<<"El Numero Ingresado es Igual a Cero"; }
 Ejemplo 2:
 if(numero > 0) // la condicion indica que tiene que ser mayor a Cero {
cout<<"El Numero Ingresado es Mayor a Cero"; }
 Ejemplo 3:
 if(numero < 0) // la condicion indica que tiene que ser menor a Cero {
cout<<"El Numero Ingresado es Menor a Cero"; }
Sentencia switch
 switch es otra de las instrucciones que permiten la construcción de estructuras
de control. A diferencia de if, para controlar el flujo por medio de una
sentencia switch se debe de combinar con el uso de las sentencias case y
break.
 Notas: cualquier número de casos a evaluar por switch así como la sentencia
default son opcionales. La sentencia switch es muy útil en los casos de
presentación de menus.
 Sintaxis:
 switch (condición) { case primer_caso: bloque de instrucciones 1 break; case
segundo_caso: bloque de instrucciones 2 break; case caso_n: bloque de
instrucciones n break; default: bloque de instrucciones por defecto }
EJEMPLOS DE SENTENCIAS SWITCH...
 Ejemplo 1
 switch (numero) { case 0: cout << “numero es cero"; }
 Ejemplo 2
 switch (opcion) { case 0: cout << “Su opcion es cero"; break; case 1: cout
<< “Su opcion es uno"; break; case 2: cout << “Su opcion es dos"; }
 Ejemplo 3
 switch (opcion) { case 1: cout << “Su opcion es 1"; break; case 2: cout <<
“Su opcion es 2"; break; case 3: cout << “Su opcion es 3"; break; default:
cout << “Elija una opcion entre 1 y 3"; }
2- Sentencias de iteración
 DEFINICIÓN
 Las Sentencias de Iteración o Ciclos son estructuras de control que repiten la
ejecución de un grupo de instrucciones. Básicamente, una sentencia de
iteración es una estructura de control condicional, ya que dentro de la misma
se repite la ejecución de una o más instrucciones mientras que una a
condición especifica se cumpla. Muchas veces tenemos que repetir un
número definido o indefinido de veces un grupo de instrucciones por lo que
en estos casos utilizamos este tipo de sentencias. en C++ los ciclos o bucles se
construyen por medio de las sentencias for, while y do - while. La sentencia for
es útil para los casos en donde se conoce de antemano el número de veces
que una o más sentencias han de repetirse. Por otro lado, la sentencia while
es útil en aquellos casos en donde no se conoce de antemano el número de
veces que una o más sentencias se tienen que repetir.
Sentencias For
 for(contador; final; incremento) { Codigo a Repetir; }
 donde:
 1. contador es una variable numérica
 2. final es la condición que se evalua para finalizar el ciclo (puede ser
independiente del contador)
 3. incremento es el valor que se suma o resta al contador
 Hay que tener en cuenta que el “for” evalua la condición de finalización
igual que el while, es decir, mientras esta se cumpla continuaran las
repeticiones.
EJEMPLOS DE SENTECIA FOR...
 Ejemplo 1:
 for(int i=1; i<=10; i++) { cout<<"Hola Mundo"; } Esto indica que el contador “i” inicia desde
1 y continuará iterando mientras i sea menor o igual a 10 ( en este caso llegará hasta 10)
e “i++" realiza la sumatoria por unidad lo que hace que el for y el contador se sumen.
Repitiendo 10 veces “HOLA MUNDO” en pantalla.
 Ejemplo 2:
 for(int i=10; i>=0; i--) { cout<<"Hola Mundo"; } Este ejemplo hace lo mismo que el primero,
salvo que el contador se inicializa a 10 en lugar de 1; y por ello cambia la condición que
se evalua así como que el contador se decrementa en lugar de ser incrementado. La
condición también puede ser independiente del contador:
 Ejemplo 3:
 int j = 20; for(int i=0; j>0; i++){ cout<<"Hola"<<i<<" - "<<j<<endl; j--; } En este ejemplo las
iteraciones continuaran mientras j sea mayor que 0, sin tener en cuenta el valor que
pueda tener i.
Sentencia while
 while(condicion) { código a Repetir }
 donde:
 1. condicion es la expresión a evaluar
EJEMPLOS DE SENTECIA WHILE...
 Ejemplo 1:
 int contador = 0; while(contador<=10) { contador=contador+1; cout<<"Hola
Mundo"; }
 El contador Indica que hasta que este llegue a el total de10 entonces se
detendrá y ya no se realizará el código contenido dentro de la sentencia
while, de lo contrario mientras el “contador” sea menor a 10 entonces el
código contenido se ejecutará desplegando hasta 10 veces “Hola Mundo”
en pantalla.
Sentencia do - while
 La sentencia do es usada generalmente en cooperación con while para garantizar que
una o más instrucciones se ejecuten al menos una vez. Por ejemplo, en la siguiente
construcción no se ejecuta nada dentro del ciclo while, el hecho es que el contador
inicialmente vale cero y la condición para que se ejecute lo que está dentro del while
es “mientras el contador sea mayor que diez”. Es evidente que a la primera evaluación
hecha por while la condición deja de cumplirse.
 int contador = 0; while(contador > 10) { contador ++;cout<<"Hola Mundo"; }
 Al modificar el segmento de código anterior usando do tenemos:
 int contador = 0; do { contador ++; cout<<"Hola Mundo"; } while(contador > 10);
 Observe cómo en el caso de do la condición es evaluada al final en lugar de al
principio del bloque de instrucciones y, por lo tanto, el código que le sigue al do se
ejecuta al menos la primera vez.
3- Sentencias break y continue
 En la sección (Sentencia switch) vimos que la sentencia break es utilizada
con el propósito de forzar un salto dentro del bloque switch hacia el final
del mismo. En esta sección volveremos a ver el uso de break, salvo que
esta ocasión la usaremos junto con las sentecias for y la sentencia while.
Además, veremos el uso de la sentencia continue.
break
 La sentencia break se usa para forzar un salto hacia el final de un ciclo
controlado por for o por while.
 Ejemplo:
 En el siguiente fragmento de código la sentencia break cierra el ciclo for
cuando la variable ( i ) es igual a 5. La salida para el mismo será:
 0 1 2 3 4
 for (int i=0; i<10; i++) { if (i == 5) break; cout << i <<" "; }
continue
 La sentencia continue se usa para ignorar una iteración dentro de un
ciclo controlado por for o por while.
 Ejemplo:
 En el siguiente fragmento de código la sentencia continue ignora la
iteración cuando la variable ( i ) es igual a 5. La salida para el mismo será:
 0 1 2 3 4 6 7 8 9
 for (int i=0; i<10; i++) { if (i == 5) continue; cout << i<< " "; }
Go to
En lenguaje C, para escribir una instrucción de salto goto (ir a), se utiliza la
sintaxis:
goto <nombre_de_la_etiqueta>
La instrucción de salto goto se puede usar en un programa, para transferir
incondicionalmente el control del mismo a la primera instrucción después de
una etiqueta, o dicho de otra forma, al ejecutar una instrucción goto, el
control del programa se transfiere (salta) a la primera instrucción después de
una etiqueta. Una etiqueta se define mediante su nombre (identificador)
seguido del carácter dos puntos (:).
Go to
 La instrucción goto transfiere incondicionalmente el control a la instrucción etiquetada
por el identificador especificado.
 goto identifier;
 La instrucción con etiqueta designada por identifier debe estar en la función actual.
Todos los nombres de identifier son miembros de un espacio de nombres interno y, por
tanto, no interfieren con otros identificadores.
 Una etiqueta de instrucción solo es significativa para una instrucción goto; de lo
contrario, se omiten las etiquetas de instrucciones. Las etiquetas no se pueden volver a
declarar.
 Un buen estilo de programación consiste en utilizar las instrucciones break, continue y
return en lugar de la instrucción goto siempre que sea posible. Sin embargo, puesto que
la instrucción break sale de un solo nivel de un bucle, puede que tenga que utilizar una
instrucción goto para salir de un bucle anidado profundamente.
ejemplo
 #include <stdio.h>
int main()
{
int n, a;
a = 0;
do
{
printf( "Introduzca un numero entero: " );
scanf( "%d", &n );
if ( n == 0 )
{
printf( "ERROR: El cero no tiene opuesto.n" );
goto etiqueta_1;
/* En el caso de que n sea un cero,
el control de programa salta a la
primera instrucción después de
etiqueta_1. */
}
printf( "El opuesto es: %dn", -n );
a += n;
} while ( n >= -10 && n <= 10 );
etiqueta_1:
printf( "Suma: %d", a );
return 0;
}
Iteraciones y decisiones en c++

Más contenido relacionado

La actualidad más candente

Estructura de Datos - Unidad 5 metodos de ordenamiento
Estructura de Datos - Unidad 5 metodos de ordenamientoEstructura de Datos - Unidad 5 metodos de ordenamiento
Estructura de Datos - Unidad 5 metodos de ordenamientoJosé Antonio Sandoval Acosta
 
TRANSMISIONES DIGITALES
TRANSMISIONES DIGITALESTRANSMISIONES DIGITALES
TRANSMISIONES DIGITALESalexlombana
 
Unidad 2 ensamblador
Unidad 2   ensambladorUnidad 2   ensamblador
Unidad 2 ensambladoreveTalavera
 
Banda ancha y banda base
Banda ancha y banda baseBanda ancha y banda base
Banda ancha y banda baseJuliitoo Mejia
 
Arreglos vectores pseint
Arreglos vectores pseintArreglos vectores pseint
Arreglos vectores pseintHEIVER CUESTA
 
Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...
Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...
Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...Marcelo Vilela Pardo
 
Parcial (estructuras repetitivas"for y while" - herrmanientas case)
Parcial (estructuras repetitivas"for y while" - herrmanientas case)Parcial (estructuras repetitivas"for y while" - herrmanientas case)
Parcial (estructuras repetitivas"for y while" - herrmanientas case)Maria B. Ramos Osorio
 
Algoritmos, dfd, pseudocodigo
Algoritmos, dfd, pseudocodigoAlgoritmos, dfd, pseudocodigo
Algoritmos, dfd, pseudocodigoAdolfoReyes24
 
Impacto social, económico y cultural del las telecomunicaciones
Impacto social, económico y cultural del las telecomunicacionesImpacto social, económico y cultural del las telecomunicaciones
Impacto social, económico y cultural del las telecomunicacionesSandy Ortega
 
Procesos Ligeros: Hilos o Hebras
Procesos Ligeros: Hilos o HebrasProcesos Ligeros: Hilos o Hebras
Procesos Ligeros: Hilos o HebrasJ M
 
Importancia de-saber-programar
Importancia de-saber-programarImportancia de-saber-programar
Importancia de-saber-programarAndres Zazueta
 
Cálculo del complemento a dos de un número binario
Cálculo del complemento a dos de un número binarioCálculo del complemento a dos de un número binario
Cálculo del complemento a dos de un número binariomijacaza
 
10 ejercicios-de-do-while
10 ejercicios-de-do-while10 ejercicios-de-do-while
10 ejercicios-de-do-whileDelvi Ramirez
 
Estructura de control repetitiva
Estructura de control repetitivaEstructura de control repetitiva
Estructura de control repetitivavillandri pachco
 
Pasos para la solución de un problema por computador
Pasos para la solución de un problema por computadorPasos para la solución de un problema por computador
Pasos para la solución de un problema por computadorgisseparrav
 
Taller algoritmos ciclo repetir
Taller algoritmos ciclo repetirTaller algoritmos ciclo repetir
Taller algoritmos ciclo repetirjmachuca
 

La actualidad más candente (20)

Estructura Repetitiva MIENTRAS (While) con PSeInt
Estructura Repetitiva MIENTRAS (While) con PSeIntEstructura Repetitiva MIENTRAS (While) con PSeInt
Estructura Repetitiva MIENTRAS (While) con PSeInt
 
Estructura de Datos - Unidad 5 metodos de ordenamiento
Estructura de Datos - Unidad 5 metodos de ordenamientoEstructura de Datos - Unidad 5 metodos de ordenamiento
Estructura de Datos - Unidad 5 metodos de ordenamiento
 
TRANSMISIONES DIGITALES
TRANSMISIONES DIGITALESTRANSMISIONES DIGITALES
TRANSMISIONES DIGITALES
 
Estructura de Datos - Unidad 6 Metodos de busqueda
Estructura de Datos - Unidad 6 Metodos de busquedaEstructura de Datos - Unidad 6 Metodos de busqueda
Estructura de Datos - Unidad 6 Metodos de busqueda
 
Unidad 2 ensamblador
Unidad 2   ensambladorUnidad 2   ensamblador
Unidad 2 ensamblador
 
Banda ancha y banda base
Banda ancha y banda baseBanda ancha y banda base
Banda ancha y banda base
 
Ejercicios
EjerciciosEjercicios
Ejercicios
 
Arreglos vectores pseint
Arreglos vectores pseintArreglos vectores pseint
Arreglos vectores pseint
 
Banderas
BanderasBanderas
Banderas
 
Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...
Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...
Diagramas de flujo - Estructuras de Control (For, While, Do Whille y Switch C...
 
Parcial (estructuras repetitivas"for y while" - herrmanientas case)
Parcial (estructuras repetitivas"for y while" - herrmanientas case)Parcial (estructuras repetitivas"for y while" - herrmanientas case)
Parcial (estructuras repetitivas"for y while" - herrmanientas case)
 
Algoritmos, dfd, pseudocodigo
Algoritmos, dfd, pseudocodigoAlgoritmos, dfd, pseudocodigo
Algoritmos, dfd, pseudocodigo
 
Impacto social, económico y cultural del las telecomunicaciones
Impacto social, económico y cultural del las telecomunicacionesImpacto social, económico y cultural del las telecomunicaciones
Impacto social, económico y cultural del las telecomunicaciones
 
Procesos Ligeros: Hilos o Hebras
Procesos Ligeros: Hilos o HebrasProcesos Ligeros: Hilos o Hebras
Procesos Ligeros: Hilos o Hebras
 
Importancia de-saber-programar
Importancia de-saber-programarImportancia de-saber-programar
Importancia de-saber-programar
 
Cálculo del complemento a dos de un número binario
Cálculo del complemento a dos de un número binarioCálculo del complemento a dos de un número binario
Cálculo del complemento a dos de un número binario
 
10 ejercicios-de-do-while
10 ejercicios-de-do-while10 ejercicios-de-do-while
10 ejercicios-de-do-while
 
Estructura de control repetitiva
Estructura de control repetitivaEstructura de control repetitiva
Estructura de control repetitiva
 
Pasos para la solución de un problema por computador
Pasos para la solución de un problema por computadorPasos para la solución de un problema por computador
Pasos para la solución de un problema por computador
 
Taller algoritmos ciclo repetir
Taller algoritmos ciclo repetirTaller algoritmos ciclo repetir
Taller algoritmos ciclo repetir
 

Similar a Iteraciones y decisiones en c++

Sentencias condicionales y ciclos
Sentencias condicionales y ciclosSentencias condicionales y ciclos
Sentencias condicionales y ciclosSohar Carr
 
Estructuras de control en Java
Estructuras de control en JavaEstructuras de control en Java
Estructuras de control en Javaquesada_diego
 
Estructuras De RepeticióN
Estructuras De RepeticióNEstructuras De RepeticióN
Estructuras De RepeticióNRegina Flores
 
Estructuras De RepeticióN
Estructuras De RepeticióNEstructuras De RepeticióN
Estructuras De RepeticióNRegina Flores
 
Instrucciones de control repetitivas
Instrucciones de control repetitivasInstrucciones de control repetitivas
Instrucciones de control repetitivasAbrirllave
 
Estructuras de control C++
Estructuras de control C++Estructuras de control C++
Estructuras de control C++LOANNELMARIN
 
Estructuras de Control - Ivan Walkes Mc.
Estructuras de Control - Ivan Walkes Mc.Estructuras de Control - Ivan Walkes Mc.
Estructuras de Control - Ivan Walkes Mc.Ivan A. Walkes Mc.
 
5.3 instruccion while
5.3 instruccion while5.3 instruccion while
5.3 instruccion whileSNPP
 
Sentencia de control
Sentencia de controlSentencia de control
Sentencia de controlStalyn Cruz
 
Universidad nacional experimental de guayana
Universidad nacional experimental de guayanaUniversidad nacional experimental de guayana
Universidad nacional experimental de guayanayankelis zorrilla
 
estructuras de repeticion
estructuras de repeticionestructuras de repeticion
estructuras de repeticionadark
 
Estructuras de control
Estructuras de controlEstructuras de control
Estructuras de controlLic_Vera
 
Toma de decisiones If Else
Toma de decisiones If ElseToma de decisiones If Else
Toma de decisiones If Elsecompumet sac
 
While y do while
While y do whileWhile y do while
While y do whilejosenassr
 

Similar a Iteraciones y decisiones en c++ (20)

Sentencias
SentenciasSentencias
Sentencias
 
Sentencias
SentenciasSentencias
Sentencias
 
Sentencias condicionales y ciclos
Sentencias condicionales y ciclosSentencias condicionales y ciclos
Sentencias condicionales y ciclos
 
Estructuras de control en Java
Estructuras de control en JavaEstructuras de control en Java
Estructuras de control en Java
 
Estructuras De RepeticióN
Estructuras De RepeticióNEstructuras De RepeticióN
Estructuras De RepeticióN
 
Estructuras De RepeticióN
Estructuras De RepeticióNEstructuras De RepeticióN
Estructuras De RepeticióN
 
Estructura repetitiva
Estructura repetitivaEstructura repetitiva
Estructura repetitiva
 
Instrucciones de control repetitivas
Instrucciones de control repetitivasInstrucciones de control repetitivas
Instrucciones de control repetitivas
 
Estructuras de control C++
Estructuras de control C++Estructuras de control C++
Estructuras de control C++
 
Manual
ManualManual
Manual
 
Estructuras de Control - Ivan Walkes Mc.
Estructuras de Control - Ivan Walkes Mc.Estructuras de Control - Ivan Walkes Mc.
Estructuras de Control - Ivan Walkes Mc.
 
Estructuras de Control
Estructuras de ControlEstructuras de Control
Estructuras de Control
 
5.3 instruccion while
5.3 instruccion while5.3 instruccion while
5.3 instruccion while
 
Sentencia de control
Sentencia de controlSentencia de control
Sentencia de control
 
Universidad nacional experimental de guayana
Universidad nacional experimental de guayanaUniversidad nacional experimental de guayana
Universidad nacional experimental de guayana
 
estructuras de repeticion
estructuras de repeticionestructuras de repeticion
estructuras de repeticion
 
While do while
While do whileWhile do while
While do while
 
Estructuras de control
Estructuras de controlEstructuras de control
Estructuras de control
 
Toma de decisiones If Else
Toma de decisiones If ElseToma de decisiones If Else
Toma de decisiones If Else
 
While y do while
While y do whileWhile y do while
While y do while
 

Último

Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíassuserf18419
 
Redes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfRedes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfsoporteupcology
 
Plan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docxPlan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docxpabonheidy28
 
Hernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptxHernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptxJOSEMANUELHERNANDEZH11
 
La era de la educación digital y sus desafios
La era de la educación digital y sus desafiosLa era de la educación digital y sus desafios
La era de la educación digital y sus desafiosFundación YOD YOD
 
KELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento ProtégelesKELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento ProtégelesFundación YOD YOD
 
trabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdftrabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdfIsabellaMontaomurill
 
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE  DE TECNOLOGIA E INFORMATICA PRIMARIACLASE  DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIAWilbisVega
 
guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan JosephBRAYANJOSEPHPEREZGOM
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveFagnerLisboa3
 
Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024GiovanniJavierHidalg
 
Proyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptxProyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptx241521559
 
9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudiante9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudianteAndreaHuertas24
 
International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)GDGSucre
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricKeyla Dolores Méndez
 
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...silviayucra2
 

Último (16)

Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnología
 
Redes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfRedes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdf
 
Plan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docxPlan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docx
 
Hernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptxHernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptx
 
La era de la educación digital y sus desafios
La era de la educación digital y sus desafiosLa era de la educación digital y sus desafios
La era de la educación digital y sus desafios
 
KELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento ProtégelesKELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento Protégeles
 
trabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdftrabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdf
 
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE  DE TECNOLOGIA E INFORMATICA PRIMARIACLASE  DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
 
guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Joseph
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial Uninove
 
Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024
 
Proyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptxProyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptx
 
9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudiante9egb-lengua y Literatura.pdf_texto del estudiante
9egb-lengua y Literatura.pdf_texto del estudiante
 
International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
 
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
 

Iteraciones y decisiones en c++

  • 1. Iteraciones y decisiones en C++ JUAN JESÚS MENDOZA GONZÁLEZ JOSÉ ÁNGEL ROSALES GARCÍA
  • 2. 1- Sentencias de decisión  DEFINICIÓN  Las sentencias de decisión o también llamadas de CONTROL DE FLUJO son estructuras de control que una pregunta la cual retorna verdadero o falso (evalúa una condición) y selecciona la siguiente instrucción a ejecutar dependiendo la respuesta o resultado.
  • 3.  En algún momento dentro de nuestros algoritmos, es preciso cambiar el flujo de ejecución de las instrucciones, es decir, el orden en que las instrucciones son ejecutadas. Muchas de las veces tenemos que tomar una decisión en cuanto a que se debe ejecutar basándonos en una respuesta de verdadero o falso (condición). La ejecución de las instrucciones incluyendo una estructura de control como el condicional funcionan de esta manera:  Las instrucciones comienzan a ejecutarse de forma secuencial (en orden) y cuando se llega a una estructura condicional, la cual esta asociada a una condición, se decide que camino tomar dependiendo siempre del resultado de la condición siendo esta falsa o verdadera.  Cuando se termina de ejecutar este bloque de instrucciones se reanuda la ejecución en la instrucción siguiente a la de la condicional.
  • 4. Sentencia if  La instrucción if es, por excelencia, la más utilizada para construir estructuras de control de flujo.  SINTAXIS  Primera Forma  Ahora bién, la sintaxis utilizada en la programación de C++ es la siguiente: if (condicion) { Set de instrucciones } siendo “condicion” el lugar donde se pondrá la condición que se tiene que cumplir para que sea verdadera la sentencia y así proceder a realizar el “set de instrucciones” o código contenido dentro de la sentencia.  Segunda Forma  Ahora veremos la misma sintaxis pero ahora le añadiremos la parte “Falsa” de la sentencia: if (condicion) { Set de instrucciones //PARTE VERDADERA } else { Set de instrucciones 2 //Parte FALSA }  La forma mostrada anteriormente muestra la union de la parte “VERDADERA” con la nueva secuencia la cual es la parte “FALSA” de la sentencia de decision “IF” en la cual esta compuesta por el: else { Set de instrucciones 2 //Parte FALSA } la palabra “else” o “De lo contrario” indica al lenguaje que de lo contrario al no ser verdadera o no se cumpla la parte verdadera entonces realizara el “set de instrucciones 2”.
  • 5. EJEMPLOS DE SENTENCIAS IF...  Ejemplo 1:  if(numero == 0) //La condicion indica que tiene que ser igual a Cero { cout<<"El Numero Ingresado es Igual a Cero"; }  Ejemplo 2:  if(numero > 0) // la condicion indica que tiene que ser mayor a Cero { cout<<"El Numero Ingresado es Mayor a Cero"; }  Ejemplo 3:  if(numero < 0) // la condicion indica que tiene que ser menor a Cero { cout<<"El Numero Ingresado es Menor a Cero"; }
  • 6. Sentencia switch  switch es otra de las instrucciones que permiten la construcción de estructuras de control. A diferencia de if, para controlar el flujo por medio de una sentencia switch se debe de combinar con el uso de las sentencias case y break.  Notas: cualquier número de casos a evaluar por switch así como la sentencia default son opcionales. La sentencia switch es muy útil en los casos de presentación de menus.  Sintaxis:  switch (condición) { case primer_caso: bloque de instrucciones 1 break; case segundo_caso: bloque de instrucciones 2 break; case caso_n: bloque de instrucciones n break; default: bloque de instrucciones por defecto }
  • 7. EJEMPLOS DE SENTENCIAS SWITCH...  Ejemplo 1  switch (numero) { case 0: cout << “numero es cero"; }  Ejemplo 2  switch (opcion) { case 0: cout << “Su opcion es cero"; break; case 1: cout << “Su opcion es uno"; break; case 2: cout << “Su opcion es dos"; }  Ejemplo 3  switch (opcion) { case 1: cout << “Su opcion es 1"; break; case 2: cout << “Su opcion es 2"; break; case 3: cout << “Su opcion es 3"; break; default: cout << “Elija una opcion entre 1 y 3"; }
  • 8. 2- Sentencias de iteración  DEFINICIÓN  Las Sentencias de Iteración o Ciclos son estructuras de control que repiten la ejecución de un grupo de instrucciones. Básicamente, una sentencia de iteración es una estructura de control condicional, ya que dentro de la misma se repite la ejecución de una o más instrucciones mientras que una a condición especifica se cumpla. Muchas veces tenemos que repetir un número definido o indefinido de veces un grupo de instrucciones por lo que en estos casos utilizamos este tipo de sentencias. en C++ los ciclos o bucles se construyen por medio de las sentencias for, while y do - while. La sentencia for es útil para los casos en donde se conoce de antemano el número de veces que una o más sentencias han de repetirse. Por otro lado, la sentencia while es útil en aquellos casos en donde no se conoce de antemano el número de veces que una o más sentencias se tienen que repetir.
  • 9. Sentencias For  for(contador; final; incremento) { Codigo a Repetir; }  donde:  1. contador es una variable numérica  2. final es la condición que se evalua para finalizar el ciclo (puede ser independiente del contador)  3. incremento es el valor que se suma o resta al contador  Hay que tener en cuenta que el “for” evalua la condición de finalización igual que el while, es decir, mientras esta se cumpla continuaran las repeticiones.
  • 10. EJEMPLOS DE SENTECIA FOR...  Ejemplo 1:  for(int i=1; i<=10; i++) { cout<<"Hola Mundo"; } Esto indica que el contador “i” inicia desde 1 y continuará iterando mientras i sea menor o igual a 10 ( en este caso llegará hasta 10) e “i++" realiza la sumatoria por unidad lo que hace que el for y el contador se sumen. Repitiendo 10 veces “HOLA MUNDO” en pantalla.  Ejemplo 2:  for(int i=10; i>=0; i--) { cout<<"Hola Mundo"; } Este ejemplo hace lo mismo que el primero, salvo que el contador se inicializa a 10 en lugar de 1; y por ello cambia la condición que se evalua así como que el contador se decrementa en lugar de ser incrementado. La condición también puede ser independiente del contador:  Ejemplo 3:  int j = 20; for(int i=0; j>0; i++){ cout<<"Hola"<<i<<" - "<<j<<endl; j--; } En este ejemplo las iteraciones continuaran mientras j sea mayor que 0, sin tener en cuenta el valor que pueda tener i.
  • 11.
  • 12. Sentencia while  while(condicion) { código a Repetir }  donde:  1. condicion es la expresión a evaluar
  • 13. EJEMPLOS DE SENTECIA WHILE...  Ejemplo 1:  int contador = 0; while(contador<=10) { contador=contador+1; cout<<"Hola Mundo"; }  El contador Indica que hasta que este llegue a el total de10 entonces se detendrá y ya no se realizará el código contenido dentro de la sentencia while, de lo contrario mientras el “contador” sea menor a 10 entonces el código contenido se ejecutará desplegando hasta 10 veces “Hola Mundo” en pantalla.
  • 14. Sentencia do - while  La sentencia do es usada generalmente en cooperación con while para garantizar que una o más instrucciones se ejecuten al menos una vez. Por ejemplo, en la siguiente construcción no se ejecuta nada dentro del ciclo while, el hecho es que el contador inicialmente vale cero y la condición para que se ejecute lo que está dentro del while es “mientras el contador sea mayor que diez”. Es evidente que a la primera evaluación hecha por while la condición deja de cumplirse.  int contador = 0; while(contador > 10) { contador ++;cout<<"Hola Mundo"; }  Al modificar el segmento de código anterior usando do tenemos:  int contador = 0; do { contador ++; cout<<"Hola Mundo"; } while(contador > 10);  Observe cómo en el caso de do la condición es evaluada al final en lugar de al principio del bloque de instrucciones y, por lo tanto, el código que le sigue al do se ejecuta al menos la primera vez.
  • 15.
  • 16. 3- Sentencias break y continue  En la sección (Sentencia switch) vimos que la sentencia break es utilizada con el propósito de forzar un salto dentro del bloque switch hacia el final del mismo. En esta sección volveremos a ver el uso de break, salvo que esta ocasión la usaremos junto con las sentecias for y la sentencia while. Además, veremos el uso de la sentencia continue.
  • 17. break  La sentencia break se usa para forzar un salto hacia el final de un ciclo controlado por for o por while.  Ejemplo:  En el siguiente fragmento de código la sentencia break cierra el ciclo for cuando la variable ( i ) es igual a 5. La salida para el mismo será:  0 1 2 3 4  for (int i=0; i<10; i++) { if (i == 5) break; cout << i <<" "; }
  • 18. continue  La sentencia continue se usa para ignorar una iteración dentro de un ciclo controlado por for o por while.  Ejemplo:  En el siguiente fragmento de código la sentencia continue ignora la iteración cuando la variable ( i ) es igual a 5. La salida para el mismo será:  0 1 2 3 4 6 7 8 9  for (int i=0; i<10; i++) { if (i == 5) continue; cout << i<< " "; }
  • 19. Go to En lenguaje C, para escribir una instrucción de salto goto (ir a), se utiliza la sintaxis: goto <nombre_de_la_etiqueta> La instrucción de salto goto se puede usar en un programa, para transferir incondicionalmente el control del mismo a la primera instrucción después de una etiqueta, o dicho de otra forma, al ejecutar una instrucción goto, el control del programa se transfiere (salta) a la primera instrucción después de una etiqueta. Una etiqueta se define mediante su nombre (identificador) seguido del carácter dos puntos (:).
  • 20. Go to  La instrucción goto transfiere incondicionalmente el control a la instrucción etiquetada por el identificador especificado.  goto identifier;  La instrucción con etiqueta designada por identifier debe estar en la función actual. Todos los nombres de identifier son miembros de un espacio de nombres interno y, por tanto, no interfieren con otros identificadores.  Una etiqueta de instrucción solo es significativa para una instrucción goto; de lo contrario, se omiten las etiquetas de instrucciones. Las etiquetas no se pueden volver a declarar.  Un buen estilo de programación consiste en utilizar las instrucciones break, continue y return en lugar de la instrucción goto siempre que sea posible. Sin embargo, puesto que la instrucción break sale de un solo nivel de un bucle, puede que tenga que utilizar una instrucción goto para salir de un bucle anidado profundamente.
  • 21. ejemplo  #include <stdio.h> int main() { int n, a; a = 0; do { printf( "Introduzca un numero entero: " ); scanf( "%d", &n ); if ( n == 0 ) { printf( "ERROR: El cero no tiene opuesto.n" ); goto etiqueta_1; /* En el caso de que n sea un cero, el control de programa salta a la primera instrucción después de etiqueta_1. */ } printf( "El opuesto es: %dn", -n ); a += n; } while ( n >= -10 && n <= 10 ); etiqueta_1: printf( "Suma: %d", a ); return 0; }