Ejercicios de Estructuras Repetitivas Ejemplos resueltos de for / while ...

1. Elaborar un programa que muestre los numeros pares comprendidos entre 10 y 20 inclusive #include<stdio.h> main() { int i; printf("Los numeros pares entre 10 y 20 inclusive son: \n"); for(i=10;i<=20;i=i+2) printf("%d \n",i); return 0; } 2. Elaborar un programa que muestre los numeros pares comprendidos entre 20 y 10 inclusive (orden descendente). # include<stdio.h> main() { int i; printf("Los numeros pares entre 20 y 10 inclusive son: \n"); for(i=20;i>=10;i=i-2) printf("%d \n",i); return 0; } 3. Mostrar la tabla de caracteres ASCII a partir del Código 32 (el espacio en blanco) hasta el Código 164 (o sea la ñ) sin incluir las minúsculas (rango del 97 al 122) # include<stdio.h> main() { int i; printf("Los Caracteres ASCII son: \n"); for(i=32;i<=164;i++) { if(i<97 || i>122) printf("%c %d \t",i,i); } return 0; } 4. Elaborar un programa que calcule la suma de los números multiplos de 3 a partir del número 9 y finaliza en el número 45, no deben incluirse en la suma los números comprendidos entre 21 y 27. # include<stdio.h> main() { int i,s; s=0; printf("Suma de los multiplos de 3: \n"); for(i=9;i<=45;i+=3) { if(i<21 || i>27)

s = s + i; } printf("la suma es %d \n",s); return 0; } 5. Elaborar un programa que calcule la suma de los números multiplos de 3 y 7 a partir del número 9 y finaliza en el numero 45, no deben incluirse en la suma los números comprendidos entre 21 y 27. # include<stdio.h> main() { int i,m3,m7,s; m3=0; m7=0; printf("Suma de los múltiplos de 3 y 7: \n"); for(i=9;i<=45;i++) { if(i<21 || i>27) { if (i%3 == 0) { m3 +=i;} if (i%7 == 0) { m7 +=i;} } } s = m3 + m7; printf("la suma es %d \n",s); return 0; } 6. Generalizar el caso: Elaborar un programa que calcule la suma de los números multiplos de M y N a partir del número X y finaliza en el numero Y, no deben incluirse en la suma los números comprendidos entre A y B. use scanf para ingresar los datos a las variables M,N,X,Y,A y B # include<stdio.h> main() { int m,n,x,y,a,b; int i,mm,mn,s; mm=0; mn=0; printf("Ingrese los valores que representan a los multiplos \n"); scanf("%d %d",m,n); printf("Ingrese el rango desde-hasta \n"); scanf("%d %d",x,y); printf("Ingrese el rango de exclusion desde-hasta \n"); scanf("%d %d",a,b); printf("Suma de los múltiplos de %d y %d: \n",m,n); for(i=x;i<=y;i++) { if(i<a || i>b) { if (i%3 == 0) { mm +=i;} if (i%7 == 0) { mn +=i;} } }

s = mm + mn; printf("la suma es %d \n",s); return 0; }

OTROS PROGRAMAS COMPLEMENTARIOS QUE PUEDEN AYUDARNOS EN LAS ESTRUCTURAS REPETITIVAS
PROGRAMA QUE DEMUESTRA EL USO DE getchar() esta funcion permite ingresar varios caracteres y da por terminado el ingreso cuando se presiona la tecla ENTER o sea \n - getchar( ) esta definida en "stdio.h" Tengase en cuenta que solo se memorizará la primera tecla presionada #include <stdio.h> main() { int i; char ch; printf("Ingresar un texto : \n"); ch = getchar(); printf("\n la primera tecla pulsada fue %c \n",ch); return 0; } EJEMPLO DE COMO SE DEBE INGRESAR UN CARACTER USANDO getche() #include <stdio.h> #include <conio.h> /* cuando quieras ingresar un caracter solamente puedes la funcion usar getche()*/ main() { char ch; printf("Ingrese un caracter : "); ch = getche(); printf("\nIngresaste : %c \n", ch); return 0; } // - observa que la tecla pulsada es la que se mostrará // - getche() esta declarada en conio.h por eso debemos incluir // la linea #include <conio.h> // - tambien debemos incluir stdio.h porque alli // se encuentra declarada printf PROGRAMA PARA INGRESAR VARIOS CARACTERES USANDO getche() el programa continuara ingresando texto hasta que se presione k #include <stdio.h> #include <conio.h> main() { int i; char ch; i = 0;

if(ch == 'k') i=1. Determinar el numero mayor de 10 numeros ingresados 2. Calcular el factorial de un número dado (El programa solo admite datos entre 3 y 8) 4. printf("\n la ultima tecla presionada fue %c \n". } Ejercicios Propuestos con For / While los siguientes ejercicios deberán ser resueltos por partida doble: una solución con "for". Determinar el numero menor de 12 numeros ingresados 3. Realizar un programa que cuente las vocales cuando se ingresa una cadena de textos con getchar() 6. Implemente el siguiente juego: el programa seleccionará un número aleatorio entre 0 y 100 y el jugador debe acertarlo. return 0. } printf("\n terminaste \n").printf("Ingresar caracteres hasta presionar k : \n").ch). Idem al anterior pero contar las consonantes . El juego termina cuando se acierte la cifra o halla realizado un máximo de 12 intentos en cuyo caso se le mostrará al jugador la calificación obtenida según la siguiente tabla: Número de intentos Categoría 1-3 Suertudo 4-6 Genio 7 No está mal 8 Se puede mejorar >= 9 Que pasa amigo 5. En cada intento el jugador propondrá una solución y se le informará si el número a acertar es menor o mayor que el propuesto. while(i == 0) { ch = getche(). otra con "while" 1.

Inicializamos una variable con el valor 1. Sin conocer las estructuras repetitivas podemos resolver el problema empleando una estructura secuencial. Dicha situación es un error de programación.Estructura repetitiva while. Una línea al final del bloque de repetición la conecta con la parte superior de la estructura repetitiva. Representación gráfica de la estructura while: No debemos confundir la representación gráfica de la estructura repetitiva while (Mientras) con la estructura condicional if (Si) Funcionamiento: En primer lugar se verifica la condición. luego imprimimos la variable. En caso que la condición sea Falsa continúa por la rama del Falso y sale de la estructura repetitiva para continuar con la ejecución del algoritmo. incrementamos nuevamente la variable y así sucesivamente. A la rama del verdadero la graficamos en la parte inferior de la condición. El bloque se repite MIENTRAS la condición sea Verdadera. si la misma resulta verdadera se ejecutan las operaciones que indicamos por la rama del Verdadero. Problema 1: Realizar un programa que imprima en pantalla los números del 1 al 100. nunca finalizará el programa. Diagrama de flujo: . Importante: Si la condición siempre retorna verdadero estamos en presencia de un ciclo repetitivo infinito.

Ahora veamos la solución empleando una estructura repetitiva while: .Si continuamos con el diagrama no nos alcanzarían las próximas 5 páginas para finalizarlo. Emplear una estructura secuencial para resolver este problema produce un diagrama de flujo y un programa en Java muy largo.

seguidamente comienza la estructura repetitiva while y disponemos la siguiente condición ( x <= 100). Al ser la condición verdadera se ejecuta el bloque de instrucciones que contiene la estructura while. Al ejecutarse la condición retorna VERDADERO porque el contenido de x (1) es menor o igual a 100.Es muy importante analizar este diagrama: La primera operación inicializa la variable x en 1. disponemos la condición x >=100 ( si x es mayor o igual a 100) no provoca ningún error sintáctico . en este caso finaliza el programa. por ejemplo. El bloque de instrucciones contiene una salida y una operación. Mientras la condición retorne verdadero se ejecuta el bloque de instrucciones. y seguidamente se incrementa la variable x en uno. Se imprime el contenido de x. si x contiene 1 luego de ejecutarse esta operación se almacenará en x un 2. Observar que si. La operación x=x + 1 se lee como "en la variable x se guarda el contenido de x más 1". Es decir. Al finalizar el bloque de instrucciones que contiene la estructura repetitiva se verifica nuevamente la condición de la estructura repetitiva y se repite el proceso explicado anteriormente. se lee MIENTRAS la variable x sea menor o igual a 100. al retornar falso la verificación de la condición se sale de la estructura repetitiva y continua el algoritmo. Lo más difícil es la definición de la condición de la estructura while y qué bloque de instrucciones se van a repetir.

System.print(x). x = x + 1. Importante: Podemos observar que el bloque repetitivo puede no ejecutarse ninguna vez si la condición retorna falso la primera vez. } } } Importante:Como podemos observar no hemos creado un objeto de la clase Scanner. Una vez planteado el diagrama debemos verificar si el mismo es una solución válida al problema (en este caso se debe imprimir los números del 1 al 100 en pantalla).out. Para las salidas utilizamos la función print. en este caso finaliza el diagrama.out. 100 101 Cuando x vale 101 la condición de la estructura repetitiva retorna falso. x=1. Programa: public class EstructuraRepetitivaWhile1 { public static void main(String[] ar) { int x.pero estamos en presencia de un error lógico porque al evaluarse por primera vez la condición retorna falso y no se ejecuta el bloque de instrucciones que queríamos repetir 100 veces. que se encuentra creada por defecto en cualquier programa que codifiquemos en Java. No existe una RECETA para definir una condición de una estructura repetitiva. La variable x debe estar inicializada con algún valor antes que se ejecute la operación x=x + 1 en caso de no estar inicializada aparece un error de compilación. while (x<=100) { System. . sino que se logra con una práctica continua solucionando problemas. Esto debido a que en este programa no hay que ingresar datos por teclado. . para ello podemos hacer un seguimiento del flujo del diagrama y los valores que toman las variables a lo largo de la ejecución: x 1 2 3 4 .").print(" .

3 .8 . Es de FUNDAMENTAL importancia analizar los diagramas de flujo y la posterior codificación en Java de los siguientes problemas.Imprimir los números del 50 al 100. Respuestas: 1 . Ejemplo: Si ingresamos 30 se debe mostrar en pantalla los números del 1 al 30.Imprimir los números del 1 al 500.Inicializar x con el valor -50 y fijar la condición x<=0.100).4..Imprimir los números del -50 al 0. Probemos algunas modificaciones de este programa y veamos que cambios se deberían hacer para: 1 . 2 .6. 2 .Recordemos que un problema no estará 100% solucionado si no hacemos el programa en Java que muestre los resultados buscados.Inicializar a x con el valor 2 y dentro del bloque repetitivo incrementar a x en 2 ( x = x + 2 ).Imprimir los números del 2 al 100 pero de 2 en 2 (2. 4 . Problema 2: Escribir un programa que solicite la carga de un valor positivo y nos muestre desde 1 hasta el valor ingresado de uno en uno.Debemos inicializar x con el valor 50.. 3 . Diagrama de flujo: . en varios problemas se presentan otras situaciones no vistas en el ejercicio anterior..Debemos cambiar la condición del while con x<=500. 4 .

Si el operador carga 10 el bloque repetitivo se ejecutará 10 veces. A la prueba del diagrama la podemos realizar dándole valores a las variables. El operador puede cargar cualquier valor.util. ya que la condición es ³Mientras x<=n ´. por ejemplo. pues x comienza en uno y se incrementa en uno cada vez que se ejecuta el bloque repetitivo.Podemos observar que se ingresa por teclado la variable n.Scanner. es decir ³mientras x sea menor o igual a 10´. . si ingresamos 5 el seguimiento es el siguiente: n x 5 1 (Se imprime el contenido de x) 2 " " 3 " " 4 " " 5 " " 6 (Sale del while porque 6 no es menor o igual a 5) Programa: import java.

print("Ingrese el valor final:").print(" .nextInt().public class EstructuraRepetitivaWhile2 { public static void main(String[] ar) { Scanner teclado=new Scanner(System. Diagrama de flujo: . int n. El contador x nos indica en cada momento la cantidad de valores impresos en pantalla.x.out. Un contador es un tipo especial de variable que se incrementa o decrementa con valores constantes durante la ejecución del programa. System. System. while (x<=n) { System.print(x). } } } Los nombres de las variables n y x pueden ser palabras o letras (como en este caso) La variable x recibe el nombre de CONTADOR.out.in). x=1. x = x + 1."). n=teclado.out. Problema 3: Desarrollar un programa que permita la carga de 10 valores por teclado y nos muestre posteriormente la suma de los valores ingresados y su promedio.

También aparece el concepto de ACUMULADOR (un acumulador es un tipo .En este problema. a semejanza de los anteriores. llevamos un CONTADOR llamado x que nos sirve para contar las vueltas que debe repetir el while.

Scanner. por ello la necesidad de ir almacenando en la variable suma los valores ingresados. Programa: import java. int x.promedio. Los números que toma la variable valor dependerá de qué cifras cargue el operador durante la ejecución del programa. suma=0.in). Cada ciclo que se repita la estructura repetitiva.valor. x=1. while (x<=10) { . La prueba del diagrama se realiza dándole valores a las variables: valor suma x promedio 0 0 (Antes de entrar a la estructura repetitiva estos son los valores). 5 5 1 16 21 2 7 28 3 10 38 4 2 40 5 20 60 6 5 65 7 5 70 8 10 80 9 2 82 10 8 90 11 9 Este es un seguimiento del diagrama planteado. la variable suma se incrementa con el contenido ingresado en la variable valor.especial de variable que se incrementa o decrementa con valores variables durante la ejecución del programa) Hemos dado el nombre de suma a nuestro acumulador.suma. public class EstructuraRepetitivaWhile3 { public static void main(String[] ar) { Scanner teclado=new Scanner(System. El promedio se calcula al salir de la estructura repetitiva (es decir primero sumamos los 10 valores ingresados y luego los dividimos por 10) Hay que tener en cuenta que cuando en la variable valor se carga el primer valor (en este ejemplo 5) al cargarse el segundo valor (16) el valor anterior 5 se pierde.util.

out.out. System.System.out.20 y 1.print("El promedio es:").out.print("Ingrese un valor:"). Diagrama de flujo: .print(promedio).println(suma). x=x+1. Confeccionar un programa que pida ingresar por teclado la cantidad de piezas a procesar y luego ingrese la longitud de cada perfil. Imprimir por pantalla la cantidad de piezas aptas que hay en el lote. System. } promedio=suma/10.print("La suma de los 10 valores es:"). System.out.nextInt(). System. } } Problema 4: Una planta que fabrica perfiles de hierro posee un lote de n piezas. suma=suma+valor.30 son aptas. sabiendo que la pieza cuya longitud esté comprendida en el rango de 1. valor=teclado.

en caso de ser correcta la CONTAMOS (incrementamos la variable cantidad en 1) .Podemos observar que dentro de una estructura repetitiva puede haber estructuras condicionales (inclusive puede haber otras estructuras repetitivas que veremos más adelante) En este problema hay que cargar inicialmente la cantidad de piezas a ingresar ( n ).20 y 1. Cada vez que ingresamos un largo de pieza (largo) verificamos si es una medida correcta (debe estar entre 1.30 el largo para que sea correcta). seguidamente se cargan n valores de largos de piezas.

n.out.print(cantidad).print("Cuantas piezar procesará:"). x=1.cantidad.out.20 && largo<=1. public class EstructuraRepetitivaWhile4 { public static void main(String[] ar) { Scanner teclado=new Scanner(System. } x=x + 1. cantidad=0. while (x<=n) { System.out.nextFloat(). int x. float largo.in).30) { cantidad = cantidad +1.Scanner.print("La cantidad de piezas aptas son:"). } } Problemas propuestos Ha llegado la parte fundamental. que es el momento donde uno desarrolla individualmente un algoritmo para la resolución de problemas.Al contador cantidad lo inicializamos en cero porque inicialmente no se ha cargado ningún largo de medida. if (largo>=1.print("Ingrese la medida de la pieza:"). System. . System. El tiempo a dedicar a esta sección EJERCICIOS PROPUESTOS debe ser mucho mayor que el empleado a la sección de EJERCICIOS RESUELTOS. } System. n=teclado.out. largo=teclado. Cuando salimos de la estructura repetitiva porque se han cargado n largos de piezas mostramos por pantalla el contador cantidad (que representa la cantidad de piezas aptas) En este problema tenemos dos CONTADORES: x (Cuenta la cantidad de piezas cargadas hasta el momento) cantidad (Cuenta los perfiles de hierro aptos) Programa: import java.util.nextInt().

Informar con un mensaje cual de las dos listas tiene un valor acumulado mayor (mensajes "Lista 1 mayor". 1. En una empresa trabajan n empleados cuyos sueldos oscilan entre $100 y $500.La experiencia dice que debemos dedicar el 80% del tiempo a la resolución individual de problemas y el otro 20% al análisis y codificación de problemas ya resueltos por otras personas. Se ingresan un conjunto de n alturas de personas por teclado. etc. 6. if (valor%2==0) //Si el if da verdadero luego es par.22 . Debe aparecer en pantalla 8 16 . espero que sea lo que buscas: . Realizar un programa que permita cargar dos listas de 15 valores cada una. Realizar un programa que imprima 25 términos de la serie 11 . "Listas iguales") Tener en cuenta que puede haber dos o más estructuras repetitivas en un algoritmo. 3. El algoritmo para calcular la división con Restas Sucesivas lo tengo así. 4. Además el programa deberá informar el importe que gasta la empresa en sueldos al personal.33 . Emplear el operador ³%´ en la condición de la estructura condicional: 8.44. Desarrollar un programa que permita cargar n números enteros y luego nos informe cuántos valores fueron pares y cuántos impares.24. Mostrar la altura promedio de las personas. realizar un programa que lea los sueldos que cobra cada empleado e informe cuántos empleados cobran entre $100 y $300 y cuántos cobran más de $300. (No se ingresan valores por teclado) 5. "Lista 2 mayor". etc. Es de vital importancia para llegar a ser un buen PROGRAMADOR poder resolver problemas en forma individual. 7. Escribir un programa que solicite ingresar 10 notas de alumnos y nos informe cuántos tienen notas mayores o iguales a 7 y cuántos menores. 2. Mostrar los múltiplos de 8 hasta el valor 500.

B el divisor. B Si A>=B Entonces CONT<-0 Mientras A>=B hacer A<-A-B CONT<-CONT+1 finmientras Escribir 'Resultado:'. CONT Inicio Escribir 'Ingrese nº Dividendo y Divisor' Leer A.Algoritmo TP3-2 Variables Entero: A. Capítulo 16: . CONT sino Escribir 'No se puede realizar la operación de división entera' finsi Fin A es el dividendo. B. si se cumple la condición para dividir sólo números enteros positivos. se va restando B a A en cada ciclo hasta que ya no sea posible y obviamente el contador (CONT) es el cociente.

se ejecuta la instrucción especificada. es decir.com/site/apren Se llama Mientras a la estructura algorítmica que se ejecuta mientras la condición evaluada resulte verdadera. Existe otro caso de estructura conocida como Salto (Goto). el bucle continúa mientras la condición es verdadera (la cual se comprueba antes de ejecutar la acción) y en el segundo.google. Se usan cuando no se conoce con anticipación el número de veces que se ejecutará la acción. el bucle continúa hasta que la condición se hace verdadera (la condición se comprueba después de ejecutar la acción. Las estructuras Mientras y Para/Desde suelen en ciertos casos. La estructura Desde/Para suele utilizarse cuando se conoce con anterioridad el número de veces que se ejecutará la acción y se le conoce como Estructura Repetitiva en lugar de iterativa. se conocen como Iterativas.repetro. La diferencia entre ambas es que la condición se sitúa al principio (Mientras) o al final (Repetir) de la secuencia de instrucciones. . Estructura mientras. la cual no es muy recomendable de usar ya que su uso dificulta la legibilidad de un programa y tiende a confundir por el hecho de recurrir a numerosas etiquetas o números de línea. se ejecutará al menos una vez). Miami sites. llamada el cuerpo del bucle. finaliza la repetición. Se evalúa la expresión booleana y. Entonces se vuelve a evaluar la expresión booleana. La estructura While y la estructura Repeat. Este proceso de evaluación de la expresión booleana y ejecución del cuerpo se repite mientras la expresión sea cierta. Entonces. En la lección anterior iniciamos con las estructuras repetitivas. y si todavía es cierta se ejecuta de nuevo el cuerpo. para diferenciarla de las dos anteriores. si es cierta.com Enlaces patrocinados Cuando se hace falsa. mientras que Repetir ejecutará el bucle al menos una vez. en el primero.Estructuras iterativas. New York. Vancouver. no realizar ninguna iteración en el bucle.Databras Regime Especial Aduaneiro Repetro Databras www. Enlaces patrocinados Inglés en Canada y USA Descuentos para Estudiantes Toronto. y Repetro .

Solución. Hoy lo haremos con la estructura Mientras. para llevar la cuenta de las veces que entramos al cuerpo del ciclo. que se necesita una variable contadora (un índice). Representación pseudocodificada: Español Inglés Mientras <condición> While <condición> do Acciones Acciones Fin_mientras end_while EJEMPLO: Calcular la suma de los cuadrados de los primeros 100 números enteros y escribir el resultado. Como recordarás. También es importante notar que esta variable se inicializa antes de entrar al cuerpo del ciclo y dentro del cuerpo se incrementa en una cantidad constante. nos sirve para compararla con el valor dado en la condición. por lo general en uno. se sale del ciclo.Que tendremos de diferente? .Observa en el flujograma. resolvimos este ejercicio en la lección anterior pero utilizando la estructura Desde. Esta variable a la vez. cuando se cumple la condición.

Cuando no se conoce a priori el número de iteraciones que se van a realizar.CENTINELAS Y BANDERAS. En un ciclo controlado por centinela el usuario puede suspender la introducción de datos cuando lo desee. Un ciclo Repetir controlado por centinela es cuando el usuario digita una letra para salir como por ejemplo S o N para indicar si desea continuar o no. el ciclo puede ser controlado por centinelas. la condición de While especifica que el cuerpo del ciclo debe continuar ejecutándose mientras la tarea no haya sido completada. En un ciclo While controlado por tarea. El bucle debe repetirse hasta que la respuesta del usuario sea "n" o "N". . CENTINELAS. introduciendo una señal adecuada llamada centinela.

. no con estructuras Desde/Para. Conocidas también como interruptores. sumgas + gasto Leer (gasto) Fin_mientras Escribir (sumgas) Fin BANDERAS. se le denomina centinela y su función primordial es detener el proceso de entrada de datos en una corrida de programa. son variables que pueden tomar solamente dos valores durante la ejecución del programa. los .Cuando una decisión toma los valores de -1 o algún posible valor que no esté dentro del rango válido en un momento determinado. Si definimos gasto1. pero no sabemos exactamente cuántos fueron. Algoritmo: Inicio Sumgas .. flags o conmutadores. un valor centinela en esta lista puede ser -999. si se tienen las calificaciones de un test (comprendida entre 0 y 100). un valor centinela puede ser un número negativo.. -1 es el centinela de fin de datos. gasto2. Los centinelas solamente pueden usarse con las estructuras Mientras y Repetir. -1 donde gastoi: real es el gasto número i y sumgas: real es el acumulador de gastos efectuados. 0 Leer (gasto) Mientras gasto <> -1 hacer Sumgas . ¿PODRÍAS DECIR POR QUÉ? Ejemplo: Suponga que debemos obtener la suma de los gastos que hicimos en nuestro último viaje. gasto3. switch.. . Por ejemplo. Si la lista de datos son números positivos. ya que nunca será una calificación válida y cuando aparezca este valor se terminará de ejecutar el bucle.

"F" Sino Serie .1/N. +/.cuales pueden ser 0 ó 1. Algoritmo: Inicio Serie .. 0 I.1/2+ 1/3 1/4 +. serie + (1/I) Band . serie ...(1/I) Band . "T" Fin_si I¬I+1 Fin_mientras Escribir (serie) . "T" Mientras I <= N hacer Si band = "T" entonces Serie . Se les suele llamar interruptores porque cuando toman los valores 0 ó 1 están simulando un interruptor abierto/cerrado o encendido/apagado. o bien los valores booleanos True o False.1 Leer (N) Band . Ejemplo 1: Leer un número entero N y calcular el resultado de la siguiente serie: 1 .

15.. 1800. 10.. 7. 12. Algoritmo: Inicio I ¬2 Sumser ¬0 Band ¬T" Mientras (I <= 1800) hacer Sumser ¬sumser + I Escribir (I) Si band = "T" entonces I ¬I + 3 Band ¬F" Sino I ¬I + 2 Band ¬T" Fin_si Fin_mientras Escribir (sumser) . 17. es variable auxiliar que indica si al siguiente término de la serie hay que sumarle 3 ó 2. Obtener suma de los términos de la serie: 2. Sumser de tipo entero. .Fin Ejemplo 2. es el acumulador de términos de la serie Band de tipo carácter.. 5.

es/OnlineEnlaces patrocinados Representación pseudocodificada : Español Inglés Repetir Repeat Acciones Acciones . Estructura repetir.mdc1.LSBF. cursos y talleres www.Fin Capítulo 17: Estructuras iterativas. Informate Aqui! www.mx Se llama Repetir a la estructura algorítmica que se ejecuta un número definido de veces hasta que la condición se torna verdadera: y Maestrias a Distancia Maestrias y Postgrados Reconocidos A Nivel Mundial. Enlaces patrocinados Entrenamiento Formacion y Certificacion de instructores.com.

Hasta que <condición> until <condición> EJEMPLO: Calcular la suma de los cuadrados de los primeros 100 números enteros y escribir el resultado. . Esto quiere decir. la condición ahora estará colocada al final del bucle para que primero ejecutamos la instrucción y luego preguntamos si la condición se cumple. ahora utilizando la estructura Repetir. También podrás observar que la condición está al revés. En el bucle Mientras. Nuevamente resolveremos el ejercicio de las dos lecciones anteriores. Solución. la condición se evaluaba mientras era cierta. que en esta estructura el bucle se realizará por lo menos una vez.¿Podrás decir cuál será ahora la diferencia? Las reglas para construcción de esta estructura usando Repetir. nos dicen que debemos declarar una variable contador que debe inicializarse antes del ciclo e incrementarse dentro del ciclo. porque el bucle se repite hasta que la condición se cumpla. A diferencia de la estructura Mientras.

repetro.Databras Regime Especial Aduaneiro Repetro Databras www.com Durante las siguientes lecciones estaremos estudiando tres estructuras básicas que son: Estructura Desde/Para Estructura Mientras .Capítulo 15: Estructuras básicas. Enlaces patrocinados Repetro .

Los contadores se utilizan con la finalidad de contar sucesos o acciones internas de un bucle. deben realizar una operación de inicialización y posteriormente las sucesivas de incremento o decremento del mismo. cuyos conceptos se describen a continuación: CONTADOR: Un contador es una variable cuyo valor se incrementa o decrementa en una cantidad constante cada vez que se produce un determinado suceso o acción. su uso y ejemplos. Para utilizar esta estructura en algoritmos. debemos hacer uso de contadores y algunas veces de acumuladores.com Enlaces patrocinados Representación pseudocodificada: Español Inglés Desde var = valor inicial hasta valor final hacer For var=valor inicial to valor final do Acciones acciones Fin_desde end_for A la estructura Desde/Para se le conoce como Repetitiva. La inicialización consiste en asignarle al contador un valor.3 GB de Capacidad y Accesible Desde Móviles Mail. . 7. Estructura Desde/Para: Se usa frecuentemente cuando se conoce de antemano el número de veces que se ejecutarán las acciones de un bucle.Google.Estructura Repetir En esta lección estudiaremos la forma general de la estructura Desde/Para. Se situará antes y fuera del bucle. y Correo Gmail Gratis Abre tu Cuenta en Google. Esta es una de sus características.

Ejemplo: i = i + 1 ACUMULADOR O TOTALIZADOR : Es una variable que suma sobre sí misma un conjunto de valores para de esta manera tener la suma de todos ellos en una sola variable. Mientras y luego Repetir. Se desea resolver el problema usando estructura Desde. . el acumulador va aumentando en una cantidad variable. Representación: <Nombre del acumulador> ¬ <nombre del acumulador> + <valor variable> Ejemplo: Calcular la suma de los cuadrados de los primeros 100 enteros y escribir el resultado. La diferencia entre un contador y un acumulador es que mientras el primero va aumentando de uno en uno. Ejemplo 2.Representación: <nombre del contador> ¬ nombre del contador> + <valor constante> Si en vez de incremento es decremento se coloca un menos en lugar del más.

Lo que queremos hacer notar por el momento. pero la diferencia con el contador N. EJERCICIO: Trata de elaborar un flujograma para encontrar el cuadrado de los primeros 25 números naturales. el cual estudiaremos en otra lección. Dentro del bucle. Dentro del bucle podrás notar que N se incrementa en 1. es que a suma le sumamos N más ella misma. es cómo funcionan el contador y el acumulador.Elaborar un flujograma para encontrar la suma de los K primeros números enteros. que al inicio no tenemos nada. En este ejemplo hemos utilizado un bucle repetir. el cual se inicializa en este caso. También debe inicializarse con cero. Nota que N es el contador. antes de entrar al bucle. ya que para sumar valores debemos partir de cero. la cual es un acumulador que lleva la suma de los números generados. . con cero. usando la estructura Desde/Para. es decir. También observa la variable suma. suma se incrementa en un número N.

.¿Qué necesitas para resolver el problema contadores o acumuladores? Modifica el flujograma del ejercicio anterior para que también te muestre la suma de dichos cuadrados. Dentro del cuerpo del bucle Desde. Hay un número importante de reglas que deben seguirse cuando se utilizan instrucciones Desde: Los valores inicial y final de la variable de control se determinan antes de que empiece la repetición y no pueden cambiarse durante la ejecución de la instrucción Desde. los valores de las variables que especifican los valores inicial y final pueden cambiar. pero no debe modificar este valor. Esta estructura hace el incremento automáticamente y se inicializa en la instrucción desde. También aprendimos a elaborar flujogramas o algoritmos usando la estructura Desde. ¿Qué necesitas agregar ahora? RESUMEN En esta lección aprendimos un poco del uso de contadores y acumuladores. La instrucción del cuerpo del bucle de una instrucción Desde puede utilizar el valor de la variable de control. pero esto no va a afectar al número de repeticiones. Esta estructura se puede usar únicamente en aquellos casos en que conocemos el número de veces que se va a realizar el ciclo.

Sign up to vote on this title
UsefulNot useful