Estructura Repetitiva While en C#
Estructura Repetitiva While en C#
Problema 1:
Diagrama de flujo:
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile1
{
class Program
{
static void Main(string[] args)
{
int x;
x = 1;
while (x <= 100)
{
[Link](x);
[Link](" - ");
x = x + 1;
}
[Link]();
}
}
}
Recordemos que un problema no estará 100% solucionado si no hacemos el
programa en C# que muestre los resultados buscados.
Probemos algunas modificaciones de este programa y veamos que cambios se
deberían hacer para:
1 - Imprimir los números del 1 al 500.
2 - Imprimir los números del 50 al 100.
3 - Imprimir los números del -50 al 0.
4 - Imprimir los números del 2 al 100 pero de 2 en 2
(2,4,6,8 ....100).
Respuestas:
1 - Debemos cambiar la condición del while con x<=500.
2 - Debemos inicializar x con el valor 50.
3 - Inicializar x con el valor -50 y fijar la condición x<=0.
4 - Inicializar a x con el valor 2 y dentro del bloque repetitivo
incrementar a x en 2
( x = x + 2 )
Problema 2:
Diagrama de flujo:
Podemos observar que se ingresa por teclado la variable n. El operador puede
cargar cualquier valor.
Si el operador carga 10 el bloque repetitivo se ejecutará 10 veces, ya que la
condición es ?Mientras x<=n ?, es decir ?mientras x sea menor o igual a 10?;
pues x comienza en uno y se incrementa en uno cada vez que se ejecuta el
bloque repetitivo.
A la prueba del diagrama la podemos realizar dándole valores a las variables;
por ejemplo, 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:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile2
{
class Program
{
static void Main(string[] args)
{
int n,x;
string linea;
[Link]("Ingrese el valor
final:");
linea=[Link]();
n=[Link](linea);
x=1;
while (x<=n)
{
[Link](x);
[Link](" - ");
x = x + 1;
}
[Link]();
}
}
}
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. Un contador es un tipo especial
de variable que se incrementa o decrementa con valores constantes durante la
ejecución del programa.
El contador x nos indica en cada momento la cantidad de valores impresos en
pantalla.
Problema 3:
Diagrama de flujo:
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.
También aparece el concepto de ACUMULADOR (un acumulador es un tipo
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. Cada ciclo que se
repita la estructura repetitiva, la variable suma se incrementa con el contenido
ingresado en la variable valor.
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
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile3
{
class Program
{
static void Main(string[] args)
{
int x,suma,valor,promedio;
string linea;
x=1;
suma=0;
while (x<=10)
{
[Link]("Ingrese un
valor:");
linea = [Link]();
valor=[Link](linea);
suma=suma+valor;
x=x+1;
}
promedio=suma/10;
[Link]("La suma de los 10
valores es:");
[Link](suma);
[Link]("El promedio es:");
[Link](promedio);
[Link]();
}
}
}
Problema 4:
Diagrama de flujo:
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 ), seguidamente se cargan n valores de largos de piezas.
Cada vez que ingresamos un largo de pieza (largo) verificamos si es una
medida correcta (debe estar entre 1.20 y 1.30 el largo para que sea correcta),
en caso de ser correcta la CONTAMOS (incrementamos la variable cantidad en
1)
Al contador cantidad lo inicializamos en cero porque inicialmente no se ha
cargado ningún largo de medida.
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:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile4
{
class Program
{
static void Main(string[] args)
{
int x,cantidad,n;
float largo;
string linea;
x=1;
cantidad=0;
[Link]("Cuantas piezar
procesará:");
linea = [Link]();
n=[Link](linea);
while (x<=n)
{
[Link]("Ingrese la medida
de la pieza:");
linea = [Link]();
largo=[Link](linea);
if (largo>=1.20 && largo<=1.30)
{
cantidad = cantidad +1;
}
x=x + 1;
}
[Link]("La cantidad de piezas
aptas son:");
[Link](cantidad);
[Link]();
}
}
}
Problemas propuestos
Ha llegado la parte fundamental, que es el momento donde uno desarrolla
individualmente un algoritmo para la resolución de problemas.
El tiempo a dedicar a esta sección EJERCICIOS PROPUESTOS debe ser
mucho mayor que el empleado a la sección de EJERCICIOS RESUELTOS.
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.
Es de vital importancia para llegar a ser un buen PROGRAMADOR poder
resolver problemas en forma individual.
namespace EstructuraRepetitivaWhile5
{
class Program
{
static void Main(string[] args)
{
int x,nota,conta1,conta2;
string linea;
x=1;
conta1=0;
conta2=0;
while (x<=10)
{
[Link]("Ingrese nota:");
linea = [Link]();
nota=[Link](linea);
if (nota>=7)
{
conta1=conta1 + 1;
}
else
{
conta2=conta2 + 1;
}
x=x + 1;
}
[Link]("Cantidad de alumnos con notas mayores o
iguales a 7:");
[Link](conta1);
[Link]("Cantidad de alumons con notas menores a
7:");
[Link](conta2);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile6
{
class Program
{
static void Main(string[] args)
{
int n,x;
float altura,suma,promedio;
string linea;
[Link]("Cuantas personas hay:");
linea = [Link]();
n=[Link](linea);
x=1;
suma=0;
while (x<=n)
{
[Link]("Ingrese la altura:");
linea = [Link]();
altura=[Link](linea);
suma=suma + altura;
x=x + 1;
}
promedio=suma/n;
[Link]("Altura promedio:");
[Link](promedio);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile7
{
class Program
{
static void Main(string[] args)
{
int n,x,conta1,conta2;
float sueldo,gastos;
string linea;
[Link]("Cuantos empleados tiene la empresa:");
linea = [Link]();
n=[Link](linea);
x=1;
conta1=0;
conta2=0;
gastos=0;
while (x<=n) {
[Link]("Ingrese el sueldo del empleado:");
linea = [Link]();
sueldo=[Link](linea);
if (sueldo<=300) {
conta1=conta1 + 1;
} else {
conta2=conta2 + 1;
}
gastos=gastos+sueldo;
x=x + 1;
}
[Link]("Cantidad de empleados con sueldos entre 100
y 300:");
[Link](conta1);
[Link]("Cantidad de empleados con sueldos mayor a
300:");
[Link](conta2);
[Link]("Gastos total de la empresa en sueldos:");
[Link](gastos);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile8
{
class Program
{
static void Main(string[] args)
{
int x,termino;
x=1;
termino=11;
while (x<=25)
{
[Link](termino);
[Link](" - ");
x=x + 1;
termino=termino + 11;
}
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile9
{
class Program
{
static void Main(string[] args)
{
int mult8;
mult8=8;
while (mult8<=500)
{
[Link](mult8);
[Link](" - ");
mult8=mult8 + 8;
}
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile10
{
class Program
{
static void Main(string[] args)
{
int valor,x,suma1,suma2;
string linea;
x=1;
suma1=0;
suma2=0;
[Link]("Primer lista");
while (x<=15)
{
[Link]("Ingrese valor:");
linea = [Link]();
valor=[Link](linea);
suma1=suma1 + valor;
x=x + 1;
}
[Link]("Segunda lista");
x=1;
while (x<=15)
{
[Link]("Ingrese valor:");
linea = [Link]();
valor=[Link](linea);
suma2=suma2 + valor;
x=x + 1;
}
if (suma1>suma2)
{
[Link]("Lista 1 mayor.");
}
else
{
if (suma2>suma1)
{
[Link]("Lista2 mayor.");
}
else
{
[Link]("Listas iguales.");
}
}
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaWhile11
{
class Program
{
static void Main(string[] args)
{
int n,x,valor,pares,impares;
string linea;
x=1;
pares=0;
impares=0;
[Link]("Cuantos números ingresará:");
linea = [Link]();
n=[Link](linea);
while (x<=n) {
[Link]("Ingrese el valor:");
linea = [Link]();
valor = [Link](linea); ;
if (valor%2==0)
{
pares=pares + 1;
}
else
{
impares=impares + 1;
}
x=x + 1;
}
[Link]("Cantadad de pares:");
[Link](pares);
[Link]("Cantidad de impares:");
[Link](impares);
[Link]();
}
}
}
Problema 1:
Diagrama de flujo:
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor1
{
class Program
{
static void Main(string[] args)
{
int f;
for(f=1;f<=100;f++)
{
[Link](f);
[Link]("-");
}
[Link]();
}
}
}
Problema 2:
Diagrama de flujo:
En este caso, a la variable del for (f) sólo se la requiere para que se repita el
bloque de instrucciones 10 veces.
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor2
{
class Program
{
static void Main(string[] args)
{
int suma,f,valor,promedio;
string linea;
suma=0;
for(f=1;f<=10;f++)
{
[Link]("Ingrese valor:");
linea=[Link]();
valor=[Link](linea);
suma=suma+valor;
}
[Link]("La suma es:");
[Link](suma);
promedio=suma/10;
[Link]("El promedio es:");
[Link](promedio);
[Link]();
}
}
}
El problema requiere que se carguen 10 valores y se sumen los mismos.
Tener en cuenta encerrar entre llaves bloque de instrucciones a repetir dentro
del for.
El promedio se calcula fuera del for luego de haber cargado los 10 valores.
Problema 3:
Diagrama de flujo:
Los contadores aprobados y reprobados deben imprimirse FUERA de la
estructura repetitiva.
Es fundamental inicializar los contadores aprobados y reprobados en cero
antes de entrar a la estructura for.
Importante: Un error común es inicializar los contadores dentro de la
estructura repetitiva. En caso de hacer esto los contadores se fijan en cero en
cada ciclo del for, por lo que al finalizar el for como máximo el contador puede
tener el valor 1.
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor3
{
class Program
{
static void Main(string[] args)
{
int aprobados,reprobados,f,nota;
string linea;
aprobados=0;
reprobados=0;
for(f=1;f<=10;f++)
{
[Link]("Ingrese la
nota:");
linea = [Link]();
nota=[Link](linea);
if (nota>=7)
{
aprobados=aprobados+1;
}
else
{
reprobados=reprobados+1;
}
}
[Link]("Cantidad de
aprobados:");
[Link](aprobados);
[Link]("Cantidad de
reprobados:");
[Link](reprobados);
[Link]();
}
}
}
Problema 4:
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor4
{
class Program
{
static void Main(string[] args)
{
int mul3,mul5,valor,f;
string linea;
mul3=0;
mul5=0;
for(f=1;f<=10;f++)
{
[Link]("Ingrese un
valor:");
linea = [Link]();
valor=[Link](linea);
if (valor%3==0)
{
mul3=mul3+1;
}
if (valor%5==0)
{
mul5=mul5+1;
}
}
[Link]("Cantidad de valores
ingresados múltiplos de 3:");
[Link](mul3);
[Link]("Cantidad de valores
ingresados múltiplos de 5:");
[Link](mul5);
[Link]();
}
}
}
Problema 5:
Diagrama de flujo:
Tenemos un contador llamado cantidad y f que es el contador del for.
La variable entera n se carga previo al inicio del for, por lo que podemos fijar el
valor final del for con la variable n.
Por ejemplo si el operador carga 5 en n la estructura repetitiva for se ejecutará
5 veces.
La variable valor se ingresa dentro de la estructura repetitiva, y se verifica si el
valor de la misma es mayor o igual a 1000, en dicho caso se incrementa en uno
el contador cantidad.
Fuera de la estructura repetitiva imprimimos el contador cantidad que tiene
almacenado la cantidad de valores ingresados mayores o iguales a 1000.
Programa:
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor5
{
class Program
{
static void Main(string[] args)
{
int cantidad,n,f,valor;
string linea;
cantidad=0;
[Link]("Cuantos valores
ingresará:");
linea = [Link]();
n=[Link](linea);
for(f=1;f<=n;f++)
{
[Link]("Ingrese el
valor:");
linea = [Link]();
valor = [Link](linea);
if (valor>=1000)
{
cantidad=cantidad+1;
}
}
[Link]("La cantidad de
valores ingresados mayores o iguales a 1000
son:");
[Link](cantidad);
[Link]();
}
}
}
Problemas propuestos
Ha llegado nuevamente la parte fundamental, que es el momento donde uno
desarrolla individualmente un algoritmo para la resolución de un problema.
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor6
{
class Program
{
static void Main(string[] args)
{
int basetri,altura,superficie,cantidad,f,n;
string linea;
cantidad=0;
[Link]("Cuantos triángulos procesará:");
linea = [Link]();
n=[Link](linea);
for(f=1;f<=n;f++)
{
[Link]("Ingrese el valor de la base:");
linea = [Link]();
basetri=[Link](linea);
[Link]("Ingrese el valor de la altura:");
linea = [Link]();
altura=[Link](linea);
superficie=basetri*altura/2;
[Link]("La superficie es:");
[Link](superficie);
if (superficie>12)
{
cantidad=cantidad+1;
}
}
[Link]("La cantidad de triángulos con superficie
superior a 12 son:");
[Link](cantidad);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor7
{
class Program
{
static void Main(string[] args)
{
int f,valor,suma;
string linea;
suma=0;
for(f=1;f<=10;f++)
{
[Link]("Ingrese un valor:");
linea = [Link]();
valor=[Link](linea);
if (f>5)
{
suma=suma+valor;
}
}
[Link]("La suma de los últimos 5 valores es:");
[Link](suma);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor8
{
class Program
{
static void Main(string[] args)
{
int f;
for(f=5;f<=50;f=f+5)
{
[Link](f);
[Link]("-");
}
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor9
{
class Program
{
static void Main(string[] args)
{
int f,valor;
string linea;
[Link]("Ingrese un valor entre 1 y 10:");
linea = [Link]();
valor=[Link](linea);
for(f=valor;f<=valor*12;f=f+valor)
{
[Link](f);
[Link]("-");
}
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor10
{
class Program
{
static void Main(string[] args)
{
int f,lado1,lado2,lado3,cant1,cant2,cant3,n;
string linea;
cant1=0;
cant2=0;
cant3=0;
[Link]("Ingrese la cantidad de triángulos:");
linea = [Link]();
n=[Link](linea);
for(f=1;f<=n;f++)
{
[Link]("Ingrese lado 1:");
linea = [Link]();
lado1=[Link](linea);
[Link]("Ingrese lado 2:");
linea = [Link]();
lado2 = [Link](linea);
[Link]("Ingrese lado 3:");
linea = [Link]();
lado3 = [Link](linea);
if (lado1==lado2 && lado1==lado3)
{
[Link]("Es un triángulo equilatero.");
cant1++;
}
else
{
if (lado1==lado2 || lado1==lado3 || lado2==lado3)
{
[Link]("Es un triángulo
isósceles.");
cant2++;
}
else
{
cant3++;
[Link]("Es un triángulo escaleno.");
}
}
}
[Link]("Cantidad de triángulos equilateros:");
[Link](cant1);
[Link]("Cantidad de triángulos isósceles:");
[Link](cant2);
[Link]("Cantidad de triángulos escalenos:");
[Link](cant3);
if (cant1<cant2 && cant1<cant3)
{
[Link]("Hay menor cantidad de triángulos
equilateros.");
}
else
{
if (cant2<cant3)
{
[Link]("Han menor cantidad de triángulos
isósceles");
}
else
{
[Link]("Han menor cantidad de triángulos
escalenos");
}
}
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor11
{
class Program
{
static void Main(string[] args)
{
int n,f,x,y,cant1,cant2,cant3,cant4;
string linea;
cant1=0;
cant2=0;
cant3=0;
cant4=0;
[Link]("Cantidad de puntos:");
linea = [Link]();
n=[Link](linea);
for(f=1;f<=n;f++)
{
[Link]("Ingrese coordenada x:");
linea = [Link]();
x=[Link](linea);
[Link]("Ingrese coordenada y:");
linea = [Link]();
y=[Link](linea);
if (x>0 && y>0)
{
cant1++;
}
else
{
if (x<0 && y>0)
{
cant2++;
}
else
{
if (x<0 && y<0)
{
cant3++;
}
else
{
if (x>0 && y<0)
{
cant4++;
}
}
}
}
}
[Link]("Cantidad de puntos en el primer
cuadrante:");
[Link](cant1);
[Link]("Cantidad de puntos en el segundo
cuadrante:");
[Link](cant2);
[Link]("Cantidad de puntos en el tercer
cuadrante:");
[Link](cant3);
[Link]("Cantidad de puntos en el cuarto
cuadrante:");
[Link](cant4);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor12
{
class Program
{
static void Main(string[] args)
{
int f,valor,negativos,positivos,mult15,sumapares;
string linea;
negativos=0;
positivos=0;
mult15=0;
sumapares=0;
for(f=1;f<=10;f++)
{
[Link]("Ingrese valor:");
linea = [Link]();
valor=[Link](linea);
if (valor<0)
{
negativos++;
}
else
{
if (valor>0)
{
positivos++;
}
}
if (valor%15==0)
{
mult15++;
}
if (valor%2==0)
{
sumapares=sumapares+valor;
}
}
[Link]("Cantidad de valores negativos:");
[Link](negativos);
[Link]("Cantidad de valores positivos:");
[Link](positivos);
[Link]("Cantidad de valores múltiplos de 15:");
[Link](mult15);
[Link]("Suma de los valores pares:");
[Link](sumapares);
[Link]();
}
}
}
using System;
using [Link];
using [Link];
using [Link];
namespace EstructuraRepetitivaFor13
{
class Program
{
static void Main(string[] args)
{
int f,edad,suma1,suma2,suma3,pro1,pro2,pro3;
string linea;
suma1=0;
suma2=0;
suma3=0;
for(f=1;f<=50;f++)
{
[Link]("Ingrese edad:");
linea = [Link]();
edad=[Link](linea);
suma1=suma1+edad;
}
pro1=suma1/50;
[Link]("Promedio de edades del turno mañana:");
[Link](pro1);
for(f=1;f<=60;f++)
{
[Link]("Ingrese edad:");
linea = [Link]();
edad = [Link](linea) ;
suma2=suma2+edad;
}
pro2=suma2/60;
[Link]("Promedio de edades del turno tarde:");
[Link](pro2);
for(f=1;f<=110;f++)
{
[Link]("Ingrese edad:");
linea = [Link]();
edad=[Link](linea);
suma3=suma3+edad;
}
pro3=suma3/110;
[Link]("Promedio de edades del turno noche:");
[Link](pro3);
if (pro1<pro2 && pro1<pro3)
{
[Link]("El turno mañana tiene un promedio menor
de edades.");
}
else
{
if (pro2<pro3)
{
[Link]("El turno tarde tiene un promedio
menor de edades.");
}
else
{
[Link]("El turno noche tiene un promedio
menor de edades.");
}
}
[Link]();
}
}
}