Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Tutorial de C# (Ejemplos de Codigo)
Tutorial de C# (Ejemplos de Codigo)
No se
requieren conceptos previos de programacin y se hace una introduccin gradual en esta
ciencia.
Se utilizan en un principio el planteo de "Diagramas de Flujo" para la resolucin de problemas
y su posterior codificacin con el lenguaje C#.
Se busca ir conociendo los rudimentos bsicos de la programacin presentando los conceptos
con ejercicios resueltos e invitando a la resolucin de otros problemas propuesto.
El curso est ideado para ser desarrollado por una persona que no conoce nada de
programacin y se utilice C# como primer lenguaje.
El objetivo fundamental de este tutorial es permitir que el estudiante pueda resolver
problemas de distinta ndole (matemticos, administrativos, grficos, contables etc.)
empleando como herramienta la computadora.
Hay que tener en cuenta que para llegar a ser programador se debe recorrer un largo
camino donde cada tema es fundamental para conceptos futuros. Es importante no
dejar temas sin entender y relacionar.
La programacin a diferencia de otras materias como podra ser la historia requiere un
estudio metdico y ordenado (en historia se puede estudiar la edad media sin tener
grandes conocimientos de la edad antigua)
La programacin es una actividad nueva para el estudiante, no hay en los estudios
primarios y secundarios una materia parecida.
Es bueno tenerse paciencia cuando los problemas no se resuelven por completo, pero
es de fundamental importancia dedicar tiempo al anlisis individual de los problemas.
Qu es un programa?
Programa: Conjunto de instrucciones que entiende un ordenador para realizar una
actividad.
Todo programa tiene un objetivo bien definido: un procesador de texto es un programa
que permite cargar, modificar e imprimir textos, un programa de ajedrez permite jugar al
ajedrez
contra
el
ordenador
u
otro
contrincante
humano.
La actividad fundamental del programador es resolver problemas empleando el
ordenador como herramienta fundamental.
Para la resolucin de un problema hay que plantear un algoritmo.
Algoritmo: Son los pasos a seguir para resolver un problema.
Diagrama de flujo
Un diagrama de flujo es la representacin grfica de un ALGORITMO.
representar los pasos para la resolucin del problema mediante un diagrama de flujo.
contenido. Podemos darle otros buenos nombres. Otros no son tan representativos, por
ejemplo HTr. Posiblemente cuando estemos resolviendo un problema dicho nombre
nos recuerde que almacenamos las horas trabajadas por el operario pero cuando pase
el tiempo y leamos el diagrama probablemente no recordemos ni entendamos qu
significa HTr.
Pasos.
1
Ingresemos
al
"Microsoft
Visual
C#
2010
Express".
2 - Creacin del proyecto. Para esto seleccionamos desde el men la opcin "Archivo" >
"Nuevo
proyecto..."
Aparece un dilogo donde debemos indicar el nombre del proyecto y seleccionar el tipo
de proyecto (elegiremos "Aplicacin de consola" y le daremos como nombre al proyecto
"CalculoSueldo"):
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CalculoSuedo
{
class Program
{
static void Main(string[] args)
{
}
}
}
A medida que avancemos en el curso veremos que significa una clase y namespace,
cual es el objetivo del using etc. por el momento nos centraremos donde codificaremos
nuestros
diagramas
de
flujo.
La codificacin del diagrama de flujo la haremos dentro de la funcin Main (la funcin
Main es la primera que se ejecuta al iniciarse un programa)
El programa completo para el calculo del sueldo de un operario conociendo la cantidad
de horas trabajadas y el costo por hora es:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CalculoSuedo
{
class Program
{
static void Main(string[] args)
{
int horasTrabajadas;
float costoHora;
float sueldo;
string linea;
Console.Write("Ingrese Horas trabajadas
por el operario:");
linea = Console.ReadLine();
horasTrabajadas = int.Parse(linea);
Console.Write("Ingrese el pago por
hora:");
linea = Console.ReadLine();
costoHora = float.Parse(linea);
sueldo = horasTrabajadas * costoHora;
Las operaciones que indicamos en el diagrama de flujo mediante la figura rectngulo la codificamos tal
cual:
sueldo = horasTrabajadas * costoHora;
Podemos ver una relacin entre las instrucciones que debemos utilizar para cada smbolo del diagrama
de flujo:
de
ejecutar
el
programa.
A los errores tipogrficos, como por ejemplo la falta de puntos y comas, nombres de
variables incorrectas, falta de parntesis, palabras claves mal escritas, etc. los
llamamos
errores
SINTACTICOS.
Un programa no se puede ejecutar sin corregir absolutamente todos los errores
sintcticos.
Existe otro tipo de errores llamados ERRORES LOGICOS. Este tipo de errores en
programas grandes (miles de lneas) son ms difciles de localizar. Por ejemplo un
programa que permite hacer la facturacin pero la salida de datos por impresora es
incorrecta.
Problema:
Hallar la superficie de un cuadrado conociendo el valor de un lado.
Diagrama de flujo:
Proyecto:
Creemos un proyecto llamado SuperficieCuadrado.
Codificamos el algoritmo en C# e introducimos dos
1
Disponemos
el
nombre
del
objeto
Console
errores sintctico:
con
minsculas.
Como podemos observar aparece subrayado la lnea donde disponemos console con
minsculas como en la lnea que imprimimos la variable superficie con maysculas. Si
modificamos y corregimos los dos errores sintcticos podremos ejecutar nuestro
programa.
Programa correctamente codificado:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SuperficieCuadrado
{
class Program
{
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SuperficieCuadrado
{
class Program
{
static void Main(string[] args)
{
int lado;
int superficie;
String linea;
Console.Write("Ingrese el valor del lado
del cuadrado:");
linea = Console.ReadLine();
lado = int.Parse(linea);
superficie = lado * lado * lado;
Problema:
Realizar la carga de dos nmeros enteros por teclado e imprimir su suma y su
producto.
Diagrama de flujo:
Tenemos dos entradas num1 y num2, dos operaciones: realizacin de la suma y del
producto de los valores ingresados y dos salidas, que son los resultados de la suma y
el producto de los valores ingresados. En el smbolo de impresin podemos indicar una
o ms salidas, eso queda a criterio del programador, lo mismo para indicar las entradas
por teclado.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SumaProductoNumeros
{
class Program
{
static void Main(string[] args)
{
int num1, num2, suma, producto;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1 = int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
suma = num1 + num2;
producto = num1 * num2;
Console.Write("La suma de los dos valores
es:");
Console.WriteLine(suma);
Console.Write("El producto de los dos
valores es:");
Console.WriteLine(producto);
Console.ReadKey();
}
}
}
Recordemos que tenemos que seguir todos los pasos vistos para la creacin de un
proyecto.
Algunas cosas nuevas que podemos notar:
Console.WriteLine(suma);
Problemas propuestos
1. Realizar la carga del lado de un cuadrado, mostrar por pantalla el permetro del
mismo (El permetro de un cuadrado se calcula multiplicando el valor del lado
por cuatro)
2. Escribir un programa en el cual se ingresen cuatro nmeros, calcular e informar
la suma de los dos primeros y el producto del tercero y el cuarto.
3. Realizar un programa que lea cuatro valores numricos e informar su suma y
promedio.
4. Se debe desarrollar un programa que pida el ingreso del precio de un artculo y
la cantidad que lleva el cliente. Mostrar lo que debe abonar el comprador.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PerimetroCuadrado
{
class Program
{
static void Main(string[] args)
{
int lado,perimetro;
string linea;
Console.Write("Ingrese el lado del cuadrado:");
linea=Console.ReadLine();
lado=int.Parse(linea);
perimetro=lado * 4;
Console.Write("El permetro del cuadrado es:");
Console.Write(perimetro);
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SumaProductos4Numeros
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3,num4,suma,producto;
string linea;
Console.Write("Ingrese primer valor:");
linea=Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea=Console.ReadLine();
num2=int.Parse(linea);
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SumaPromedio
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3,num4,suma,promedio;
string linea;
Console.Write("Ingrese primer valor:");
linea=Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea=Console.ReadLine();
num2=int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea=Console.ReadLine();
num3=int.Parse(linea);
Console.Write("Ingrese cuarto valor:");
linea=Console.ReadLine();
num4=int.Parse(linea);
suma=num1 + num2 + num3 + num4;
promedio=suma/4;
Console.Write("La suma de los cuatro valores es:");
Console.WriteLine(suma);
Console.Write("El promedio es:");
Console.Write(promedio);
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CostoCompra
{
class Program
{
static void Main(string[] args)
{
int cantidad;
float precio,importe;
string linea;
Console.Write("Ingrese la cantidad de artculos a
llevar:");
linea=Console.ReadLine();
cantidad=int.Parse(linea);
Console.Write("Ingrese el valor unitario del
producto:");
linea=Console.ReadLine();
precio=float.Parse(linea);
importe=precio * cantidad;
Console.Write("El importe total a pagar es:");
Console.Write(importe);
Console.ReadKey();
}
}
}
Podemos observar: El rombo representa la condicin. Hay dos opciones que se pueden
tomar. Si la condicin da verdadera se sigue el camino del verdadero, o sea el de la
derecha, si la condicin da falsa se sigue el camino de la izquierda.
Se trata de una estructura CONDICIONAL SIMPLE porque por el camino del verdadero
hay actividades
y por el camino del falso
no hay actividades.
Por el camino del verdadero pueden existir varias operaciones, entradas y salidas,
inclusive ya veremos que puede haber otras estructuras condicionales.
Problema:
Ingresar el sueldo de una persona, si supera los 3000 pesos mostrar un mensaje en
pantalla indicando que debe abonar impuestos.
Diagrama de flujo:
Podemos observar lo siguiente: Siempre se hace la carga del sueldo, pero si el sueldo
que ingresamos supera 3000 pesos se mostrar por pantalla el mensaje "Esta persona
debe abonar impuestos", en caso que la persona cobre 3000 o menos no aparece nada
por pantalla.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraCondicionalSimple1
{
class Program
{
static void Main(string[] args)
{
float sueldo;
string linea;
Console.Write("Ingrese el sueldo:");
linea=Console.ReadLine();
sueldo=float.Parse(linea);
if (sueldo>3000)
{
Console.Write("Esta persona debe abonar
impuestos");
}
Console.ReadKey();
}
}
}
La palabra clave "if" indica que estamos en presencia de una estructura condicional;
seguidamente disponemos la condicin entre parntesis. Por ltimo encerrada entre
llaves las instrucciones de la rama del verdadero.
Es necesario que las instrucciones a ejecutar en caso que la condicin sea verdadera estn encerradas
entre llaves { }, con ellas marcamos el comienzo y el fin del bloque del verdadero.
Ejecutando el programa e ingresamos un sueldo superior a 3000 pesos. Podemos observar como
aparece en pantalla el mensaje "Esta persona debe abonar impuestos", ya que la condicin del if
es verdadera.
Volvamos a ejecutar el programa y carguemos un sueldo menor o igual a 3000 pesos. No debe
aparecer mensaje en pantalla.
Representacin grfica:
En una estructura condicional compuesta tenemos entradas, salidas, operaciones, tanto por la
rama del verdadero como por la rama del falso.
Problema:
Realizar un programa que solicite ingresar dos nmeros distintos y muestre por pantalla el mayor
de ellos.
Diagrama de flujo:
Se hace la entrada de num1 y num2 por teclado. Para saber cual variable tiene un valor mayor
preguntamos si el contenido de num1 es mayor (>) que el contenido de num2, si la respuesta es
verdadera vamos por la rama de la derecha e imprimimos num1, en caso que la condicin sea
falsa vamos por la rama de la izquierda (Falsa) e imprimimos num2.
Como podemos observar nunca se imprimen num1 y num2 simultneamente.
Estamos en presencia de una ESTRUCTURA CONDICIONAL COMPUESTA ya que tenemos
actividades por la rama del verdadero y del falso.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraCondicionalCompuesta1
{
class Program
{
static void Main(string[] args)
{
int num1, num2;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1 = int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
if (num1 > num2)
{
Console.Write(num1);
}
else
{
Console.Write(num2);
}
Console.ReadKey();
}
}
}
Cotejemos el diagrama de flujo y la codificacin y observemos que el primer bloque de llaves
despus del if representa la rama del verdadero y el segundo bloque de llaves representa la rama
del falso.
Compilemos el programa, si hubo errores sintcticos corrijamos y carguemos dos valores, como
por ejemplo:
Ingrese el primer valor: 10
Ingrese el segundo valor: 4
10
Si ingresamos los valores 10 y 4 la condicin del if retorna verdadero y ejecuta el primer bloque.
Un programa se controla y corrige probando todos sus posibles resultados.
Ejecutemos nuevamente el programa e ingresemos:
Ingrese el primer valor: 10
Ingrese el segundo valor: 54
54
Cuando a un programa le corregimos todos los errores sintcticos y lgicos ha terminado nuestra
tarea y podemos entregar el mismo al USUARIO que nos lo solicit.
Operadores
En una condicin deben disponerse nicamente variables, valores constantes y operadores
relacionales.
>Operadores Relacionales:
>
(mayor)
<
>=
<=
==
!=
(menor)
(mayor o igual)
(menor o igual)
(igual)
(distinto)
Operadores Matemticos
+
*
/
%
(ms)
(menos)
(producto)
(divisin)
(resto de una divisin)
Ej.:
x=13%5;
{se guarda 3}
Hay que tener en cuenta que al disponer una condicin debemos seleccionar que operador
relacional se adapta a la pregunta.
Ejemplos:
Se ingresa un nmero multiplicarlo por 10 si es distinto a 0.
(!=)
Se ingresan dos nmeros mostrar una advertencia si son iguales. (==)
Los problemas que se pueden presentar son infinitos y la correcta eleccin del operador slo se
alcanza con la prctica intensiva en la resolucin de problemas.
Problemas propuestos
1. Realizar un programa que lea por teclado dos nmeros, si el primero es mayor al segundo
informar su suma y diferencia, en caso contrario informar el producto y la divisin del primero
respecto al segundo.
2. Se ingresan tres notas de un alumno, si el promedio es mayor o igual a siete mostrar un mensaje
"Promocionado".
3. Se ingresa por teclado un nmero positivo de uno o dos dgitos (1..99) mostrar un mensaje
indicando si el nmero tiene uno o dos dgitos.
(Tener en cuenta que condicin debe cumplirse para tener dos dgitos, un nmero entero)
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraCondicionalCompuesta2
{
class Program
{
static void Main(string[] args)
{
int num1,num2;
string linea;
Console.Write("Ingrese primer valor:");
linea=Console.ReadLine();
num1=int.Parse(linea);
nota2=int.Parse(linea);
Console.Write("Ingrese tercer nota:");
linea=Console.ReadLine();
nota3=int.Parse(linea);
int promedio;
promedio=(nota1 + nota2 + nota3) / 3;
if (promedio>=7)
{
Console.Write("Promocionado");
}
Console.ReadKey();
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EstructuraCondicionalCompuesta3
{
class Program
{
static void Main(string[] args)
{
int num;
string linea;
Console.Write("Ingrese un valor entero de 1 o 2
dgitos:");
linea=Console.ReadLine();
num=int.Parse(linea);
if (num<10)
{
Console.Write("Tiene un dgito");
}
else
{
Console.Write("Tiene dos dgitos");
}
Console.ReadKey();
}
}
}
Problema:
Confeccionar un programa que pida por teclado tres notas de un alumno, calcule el
promedio
e
imprima
alguno
de
estos
mensajes:
Si
el
promedio
es
>=7
mostrar
"Promocionado".
Si
el
promedio
es
>=4
y
<7
mostrar
"Regular".
Si el promedio es <4 mostrar "Reprobado".
Diagrama de flujo:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraCondicionalAnidada1
{
class Program
{
static void Main(string[] args)
{
int nota1,nota2,nota3;
string linea;
Console.Write("Ingrese primer nota:");
linea = Console.ReadLine();
nota1=int.Parse(linea);
Console.Write("Ingrese segunda nota:");
linea = Console.ReadLine();
nota2 = int.Parse(linea);
Console.Write("Ingrese tercer nota:");
linea = Console.ReadLine();
nota3 = int.Parse(linea);
int promedio=(nota1 + nota2 + nota3) / 3;
if (promedio>=7)
{
Console.Write("Promocionado");
}
else
{
if (promedio>=4)
{
Console.Write("Regular");
}
else
{
Console.Write("Reprobado");
}
}
Console.ReadKey();
}
}
}
Codifiquemos y ejecutemos este programa. Al correr el programa deber solicitar por
teclado la carga de tres notas y mostrarnos un mensaje segn el promedio de las
mismas.
Podemos definir un conjunto de variables del mismo tipo en una misma lnea:
int nota1,nota2,nota3;
Esto no es obligatorio pero a veces, por estar relacionadas, conviene.
A la codificacin del if anidado podemos observarla por el else del primer if.
Para no tener problemas (olvidarnos) con las llaves de apertura y cerrado podemos ver
la
siguiente
regla:
Cada vrtice representa una llave de apertura y una de cierre:
Problemas propuestos
1. Se cargan por teclado tres nmeros distintos. Mostrar por pantalla el mayor de ellos.
2. Se ingresa por teclado un valor entero, mostrar una leyenda que indique si el nmero es
positivo, nulo o negativo.
3. Confeccionar un programa que permita cargar un nmero entero positivo de hasta tres
cifras y muestre un mensaje indicando si tiene 1, 2, o 3 cifras. Mostrar un mensaje de
error si el nmero de cifras es mayor.
4. Un postulante a un empleo, realiza un test de capacitacin, se obtuvo la siguiente
informacin: cantidad total de preguntas que se le realizaron y la cantidad de preguntas
que contest correctamente. Se pide confeccionar un programa que ingrese los dos
datos por teclado e informe el nivel del mismo segn el porcentaje de respuestas
correctas que ha obtenido, y sabiendo que:
5.
6.
7.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraCondicionalAnidada2
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segunda valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea = Console.ReadLine();
num3 = int.Parse(linea);
if (num1>num2)
{
if (num1>num3)
{
Console.Write(num1);
}
else
{
Console.Write(num3);
}
}
else
{
if (num2>num3)
{
Console.Write(num2);
}
else
{
Console.Write(num3);
}
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraCondicionalAnidada3
{
class Program
{
static void Main(string[] args)
{
int num;
string linea;
Console.Write("Ingrese un valor:");
linea = Console.ReadLine();
num=int.Parse(linea);
if (num==0)
{
Console.Write("Se ingres el cero");
}
else
{
if (num>0)
{
Console.Write("Se ingres un valor
positivo");
}
else
{
Console.Write("Se ingres un valor
negativo");
}
}
Console.ReadKey();
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EstructuraCondicionalAnidada4
{
class Program
{
static void Main(string[] args)
{
int num;
string linea;
Console.Write("Ingrese un valor de hasta tres
dgitos positivo:");
linea = Console.ReadLine();
num=int.Parse(linea);
if (num<10)
{
Console.Write("Tiene un dgito");
}
else
{
if (num<100)
{
Console.Write("Tiene dos dgitos");
}
else
{
if (num<1000)
{
Console.Write("Tiene tres dgitos");
}
else
{
Console.Write("Error en la entrada de
datos.");
}
}
}
Console.ReadKey();
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EstructuraCondicionalAnidada4
{
class Program
{
static void Main(string[] args)
{
int totalPreguntas,totalCorrectas;
string linea;
Operador &&
Problema:
Confeccionar un programa que lea por teclado tres nmeros distintos y nos muestre el
mayor.
Diagrama de flujo:
Este ejercicio est resuelto sin emplear operadores lgicos en un concepto anterior del
tutorial. La primera estructura condicional es una ESTRUCTURA CONDICIONAL
COMPUESTA
con
una
CONDICION
COMPUESTA.
Podemos
leerla
de
la
siguiente
forma:
Si el contenido de la variable num1 es mayor al contenido de la variable num2 Y si el
contenido de la variable num1 es mayor al contenido de la variable num3 entonces la
CONDICION
COMPUESTA
resulta
Verdadera.
Si una de las condiciones simples da falso la CONDICION COMPUESTA da Falso y
continua
por
la
rama
del
falso.
Es decir que se mostrar el contenido de num1 si y slo si num1>num2 y num1>num3.
En caso de ser Falsa la condicin, analizamos el contenido de num2 y num3 para ver
cual
tiene
un
valor
mayor.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionCompuesta1
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea = Console.ReadLine();
num3 = int.Parse(linea);
if (num1>num2 && num1>num3)
{
Console.Write(num1);
}
else
{
if (num2>num3)
{
Console.Write(num2);
}
else
{
Console.Write(num3);
}
}
Console.ReadKey();
}
}
}
Operador ||
Problema:
Se carga una fecha (da, mes y ao) por teclado. Mostrar un mensaje si corresponde al
primer trimestre del ao (enero, febrero o marzo) Cargar por teclado el valor numrico
del
da,
mes
y
ao.
Ejemplo: dia:10 mes:1 ao:2010.
Diagrama de flujo:
La carga de una fecha se hace por partes, ingresamos las variables dia, mes y ao.
Mostramos el mensaje "Corresponde al primer trimestre" en caso que el mes ingresado
por
teclado
sea
igual
a
1,
2
3.
En la condicin no participan las variables dia y ao.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionCompuesta2
{
class Program
{
static void Main(string[] args)
{
int dia,mes,ao;
string linea;
Console.Write("Ingrese nro de da:");
linea = Console.ReadLine();
dia = int.Parse(linea); ;
Console.Write("Ingrese nro de mes:");
linea = Console.ReadLine();
mes=int.Parse(linea);
Console.Write("Ingrese nro de ao:");
linea = Console.ReadLine();
ao=int.Parse(linea);
if (mes==1 || mes==2 || mes==3)
{
Console.Write("Corresponde al primer
trimestre");
}
Console.ReadLine();
}
}
}
Problemas propuestos
1. Realizar un programa que pida cargar una fecha cualquiera, luego verificar si
dicha fecha corresponde a Navidad.
2. Se ingresan tres valores por teclado, si todos son iguales se imprime la suma del
primero con el segundo y a este resultado se lo multiplica por el tercero.
3. Se ingresan por teclado tres nmeros, si todos los valores ingresados son
menores a 10, imprimir en pantalla la leyenda "Todos los nmeros son menores
a diez".
4. Se ingresan por teclado tres nmeros, si al menos uno de los valores ingresados
es menor a 10, imprimir en pantalla la leyenda "Alguno de los nmeros es menor
a diez".
5. Escribir un programa que pida ingresar la coordenada de un punto en el plano,
es
decir
dos
valores
enteros
x
e
y
(distintos
a
cero).
Posteriormente imprimir en pantalla en que cuadrante se ubica dicho punto. (1
Cuadrante si x > 0 Y y > 0 , 2 Cuadrante: x < 0 Y y > 0, etc.)
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas3
{
class Program
{
static void Main(string[] args)
{
int dia,mes,ao;
string linea;
Console.Write("Ingrese nro de da:");
linea = Console.ReadLine();
dia=int.Parse(linea);
Console.Write("Ingrese nro de mes:");
linea = Console.ReadLine();
mes=int.Parse(linea);
Console.Write("Ingrese nro de ao:");
linea = Console.ReadLine();
ao = int.Parse(linea);
if (mes==12 && dia==25)
{
Console.Write("La fecha ingresada corresponde a
navidad.");
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas4
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea = Console.ReadLine();
num3 = int.Parse(linea);
if (num1==num2 && num1==num3)
{
int suma=num1 + num2;
Console.Write("La suma del primero y segundo:");
Console.WriteLine(suma);
int producto=suma * num3;
Console.Write("La suma del primero y segundo
multiplicado por el tercero:");
Console.Write(producto);
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas5
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3;
string linea;
Console.Write("Ingrese primer valor:");
linea=Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea=Console.ReadLine();
num2=int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea=Console.ReadLine();
num3=int.Parse(linea);
if (num1<10 && num2<10 && num3<10)
{
Console.Write("Todos los nmeros son menores a
diez");
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas6
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea = Console.ReadLine();
num3 = int.Parse(linea);
if (num1<10 || num2<10 || num3<10)
{
Console.Write("Alguno de los nmeros es menor a
diez");
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas7
{
class Program
{
static void Main(string[] args)
{
int x, y;
string linea;
Console.Write("Ingrese coordenada x:");
linea = Console.ReadLine();
x = int.Parse(linea);
Console.Write("Ingrese coordenada y:");
linea = Console.ReadLine();
y = int.Parse(linea);
if (x > 0 && y > 0)
{
Console.Write("Se encuentra en el primer
cuadrante");
}
else
{
if (x < 0 && y > 0)
{
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas8
{
class Program
{
static void Main(string[] args)
{
float sueldo;
int antiguedad;
string linea;
Console.Write("Ingrese sueldo del empleado:");
linea = Console.ReadLine();
sueldo=float.Parse(linea);
Console.Write("Ingrese su antiguedad en aos:");
linea = Console.ReadLine();
antiguedad=int.Parse(linea);
if (sueldo<500 && antiguedad>10)
{
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CondicionesCompuestas9
{
class Program
{
static void Main(string[] args)
{
int num1,num2,num3;
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
num1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
num2 = int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea = Console.ReadLine();
num3 = int.Parse(linea);
Console.Write("Rango de valores:");
if (num1num2 && num1>num3)
{
Console.Write(num1);
}
else
{
if (num2>num3)
{
Console.Write(num2);
}
else
{
Console.Write(num3);
}
}
Console.ReadKey();
}
}
}
Problema 1:
Realizar un programa que imprima en pantalla los nmeros del 1 al 100.
Sin conocer las estructuras repetitivas podemos resolver el problema empleando una
estructura secuencial. Inicializamos una variable con el valor 1, luego imprimimos la
variable, incrementamos nuevamente la variable y as sucesivamente.
Diagrama de flujo:
Es
muy
importante
analizar
este
diagrama:
La primera operacin inicializa la variable x en 1, seguidamente comienza la estructura
repetitiva while y disponemos la siguiente condicin ( x <= 100), se lee MIENTRAS la
variable x sea menor o igual a 100.
Al ejecutarse la condicin retorna VERDADERO porque el contenido de x (1) es menor
o igual a 100. Al ser la condicin verdadera se ejecuta el bloque de instrucciones que
contiene la estructura while. El bloque de instrucciones contiene una salida y una
operacin.
Se imprime el contenido de x, y seguidamente se incrementa la variable x en uno.
La operacin x=x + 1 se lee como "en la variable x se guarda el contenido de x ms 1".
Es decir, si x contiene 1 luego de ejecutarse esta operacin se almacenar en x un 2.
Al finalizar el bloque de instrucciones que contiene la estructura repetitiva se verifica
nuevamente la condicin de la estructura repetitiva y se repite el proceso explicado
anteriormente.
Mientras la condicin retorne verdadero se ejecuta el bloque de instrucciones; al
retornar falso la verificacin de la condicin se sale de la estructura repetitiva y continua
el algoritmo, en este caso finaliza el programa.
Lo ms difcil es la definicin de la condicin de la estructura while y qu bloque de
instrucciones se van a repetir. Observar que si, por ejemplo, disponemos la condicin x
>=100 ( si x es mayor o igual a 100) no provoca ningn error sintctico pero estamos
en presencia de un error lgico porque al evaluarse por primera vez la condicin
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile1
{
class Program
{
static void Main(string[] args)
{
int x;
x = 1;
while (x <= 100)
{
Console.Write(x);
Console.Write(" - ");
x = x + 1;
}
Console.ReadKey();
}
}
}
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
deberan hacer para:
1 - Imprimir los nmeros del 1 al 500.
2 - Imprimir los nmeros del 50 al 100.
3 - Imprimir los nmeros del -50 al 0.
4 - Imprimir los nmeros del 2 al 100 pero de 2 en 2 (2,4,6,8
....100).
Respuestas:
1 - Debemos cambiar la condicin del while con x<=500.
2 - Debemos inicializar x con el valor 50.
3 - Inicializar x con el valor -50 y fijar la condicin 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:
Escribir un programa que solicite la carga de un valor positivo y nos muestre desde 1
hasta
el
valor
ingresado
de
uno
en
uno.
Ejemplo: Si ingresamos 30 se debe mostrar en pantalla los nmeros del 1 al 30.
Es de FUNDAMENTAL importancia analizar los diagramas de flujo y la posterior
codificacin en C# de los siguientes problemas, en varios problemas se presentan otras
situaciones no vistas en el ejercicio anterior.
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 condicin
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 dndole 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 System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EstructuraRepetitivaWhile2
{
class Program
{
static void Main(string[] args)
{
int n,x;
string linea;
Console.Write("Ingrese el valor final:");
linea=Console.ReadLine();
n=int.Parse(linea);
x=1;
while (x<=n)
{
Console.Write(x);
Console.Write(" - ");
x = x + 1;
}
Console.ReadKey();
}
}
}
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 ejecucin
del
programa.
El contador x nos indica en cada momento la cantidad de valores impresos en pantalla.
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.
Diagrama de flujo:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile3
{
class Program
{
static void Main(string[] args)
{
int x,suma,valor,promedio;
string linea;
x=1;
suma=0;
while (x<=10)
{
Console.Write("Ingrese un valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
suma=suma+valor;
x=x+1;
}
promedio=suma/10;
Console.Write("La suma de los 10 valores
es:");
Console.WriteLine(suma);
Console.Write("El promedio es:");
Console.Write(promedio);
Console.ReadKey();
}
}
}
Problema 4:
Una planta que fabrica perfiles de hierro posee un lote de n piezas.
Confeccionar un programa que pida ingresar por teclado la cantidad de piezas a
procesar y luego ingrese la longitud de cada perfil; sabiendo que la pieza cuya longitud
est comprendida en el rango de 1,20 y 1,30 son aptas. Imprimir por pantalla la
cantidad de piezas aptas que hay en el lote.
Diagrama de flujo:
Podemos observar que dentro de una estructura repetitiva puede haber estructuras
condicionales (inclusive puede haber otras estructuras repetitivas que veremos ms
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
ningn
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
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile4
{
class Program
{
static void Main(string[] args)
{
int x,cantidad,n;
float largo;
string linea;
x=1;
cantidad=0;
Console.Write("Cuantas piezar
procesar:");
linea = Console.ReadLine();
n=int.Parse(linea);
while (x<=n)
{
Console.Write("Ingrese la medida de
la pieza:");
linea = Console.ReadLine();
largo=float.Parse(linea);
if (largo>=1.20 && largo<=1.30)
{
cantidad = cantidad +1;
}
x=x + 1;
}
Console.Write("La cantidad de piezas
aptas son:");
Console.Write(cantidad);
Console.ReadKey();
}
}
}
Problemas propuestos
Ha llegado la parte fundamental, que es el momento donde uno desarrolla
individualmente un algoritmo para la resolucin de problemas.
El tiempo a dedicar a esta seccin EJERCICIOS PROPUESTOS debe ser mucho
mayor que el empleado a la seccin de EJERCICIOS RESUELTOS.
La experiencia dice que debemos dedicar el 80% del tiempo a la resolucin individual
de problemas y el otro 20% al anlisis y codificacin de problemas ya resueltos por
otras
personas.
Es de vital importancia para llegar a ser un buen PROGRAMADOR poder resolver
problemas en forma individual.
1. Escribir un programa que solicite ingresar 10 notas de alumnos y nos informe
cuntos tienen notas mayores o iguales a 7 y cuntos menores.
2. Se ingresan un conjunto de n alturas de personas por teclado. Mostrar la altura
promedio de las personas.
3. En una empresa trabajan n empleados cuyos sueldos oscilan entre $100 y $500,
realizar un programa que lea los sueldos que cobra cada empleado e informe
cuntos empleados cobran entre $100 y $300 y cuntos cobran ms de $300.
Adems el programa deber informar el importe que gasta la empresa en
sueldos al personal.
4. Realizar un programa que imprima 25 trminos de la serie 11 - 22 - 33 - 44, etc.
(No se ingresan valores por teclado)
5. Mostrar los mltiplos de 8 hasta el valor 500. Debe aparecer en pantalla 8 - 16 24, etc.
6. Realizar un programa que permita cargar dos listas de 15 valores cada una.
Informar con un mensaje cual de las dos listas tiene un valor acumulado mayor
(mensajes "Lista 1 mayor", "Lista 2 mayor", "Listas iguales")
Tener en cuenta que puede haber dos o ms estructuras repetitivas en un
algoritmo.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
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)
{
Console.Write("Ingrese nota:");
linea = Console.ReadLine();
nota=int.Parse(linea);
if (nota>=7)
{
conta1=conta1 + 1;
}
else
{
conta2=conta2 + 1;
}
x=x + 1;
}
Console.Write("Cantidad de alumnos con notas mayores
o iguales a 7:");
Console.WriteLine(conta1);
Console.Write("Cantidad de alumons con notas menores
a 7:");
Console.Write(conta2);
Console.ReadKey();
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile6
{
class Program
{
static void Main(string[] args)
{
int n,x;
float altura,suma,promedio;
string linea;
Console.Write("Cuantas personas hay:");
linea = Console.ReadLine();
n=int.Parse(linea);
x=1;
suma=0;
while (x<=n)
{
Console.Write("Ingrese la altura:");
linea = Console.ReadLine();
altura=float.Parse(linea);
suma=suma + altura;
x=x + 1;
}
promedio=suma/n;
Console.Write("Altura promedio:");
Console.Write(promedio);
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile7
{
class Program
{
static void Main(string[] args)
{
int n,x,conta1,conta2;
float sueldo,gastos;
string linea;
Console.Write("Cuantos empleados tiene la
empresa:");
linea = Console.ReadLine();
n=int.Parse(linea);
x=1;
conta1=0;
conta2=0;
gastos=0;
while (x<=n) {
Console.Write("Ingrese el sueldo del
empleado:");
linea = Console.ReadLine();
sueldo=float.Parse(linea);
if (sueldo<=300) {
conta1=conta1 + 1;
} else {
conta2=conta2 + 1;
}
gastos=gastos+sueldo;
x=x + 1;
}
Console.Write("Cantidad de empleados con sueldos
entre 100 y 300:");
Console.WriteLine(conta1);
Console.Write("Cantidad de empleados con sueldos
mayor a 300:");
Console.WriteLine(conta2);
Console.Write("Gastos total de la empresa en
sueldos:");
Console.WriteLine(gastos);
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile8
{
class Program
{
static void Main(string[] args)
{
int x,termino;
x=1;
termino=11;
while (x<=25)
{
Console.Write(termino);
Console.Write(" - ");
x=x + 1;
termino=termino + 11;
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile9
{
class Program
{
static void Main(string[] args)
{
int mult8;
mult8=8;
while (mult8<=500)
{
Console.Write(mult8);
Console.Write(" - ");
mult8=mult8 + 8;
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile10
{
class Program
{
static void Main(string[] args)
{
int valor,x,suma1,suma2;
string linea;
x=1;
suma1=0;
suma2=0;
Console.Write("Primer lista");
while (x<=15)
{
Console.Write("Ingrese valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
suma1=suma1 + valor;
x=x + 1;
}
Console.Write("Segunda lista");
x=1;
while (x<=15)
{
Console.Write("Ingrese valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
suma2=suma2 + valor;
x=x + 1;
}
if (suma1>suma2)
{
Console.Write("Lista 1 mayor.");
}
else
{
if (suma2>suma1)
{
Console.Write("Lista2 mayor.");
}
else
{
Console.Write("Listas iguales.");
}
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaWhile11
{
class Program
{
static void Main(string[] args)
{
int n,x,valor,pares,impares;
string linea;
x=1;
pares=0;
impares=0;
Console.Write("Cuantos nmeros ingresar:");
linea = Console.ReadLine();
n=int.Parse(linea);
while (x<=n) {
Console.Write("Ingrese el valor:");
linea = Console.ReadLine();
valor = int.Parse(linea); ;
if (valor%2==0)
{
pares=pares + 1;
}
else
{
impares=impares + 1;
}
x=x + 1;
}
Console.Write("Cantadad de pares:");
Console.WriteLine(pares);
Console.Write("Cantidad de impares:");
Console.Write(impares);
Console.ReadKey();
}
}
}
En su forma ms tpica y bsica, esta estructura requiere una variable entera que
cumple la funcin de un CONTADOR de vueltas. En la seccin indicada como
"inicializacin contador", se suele colocar el nombre de la variable que har de
contador, asignndole a dicha variable un valor inicial. En la seccin de "condicin" se
coloca la condicin que deber ser verdadera para que el ciclo contine (en caso de un
falso, el ciclo se detendr). Y finalmente, en la seccin de "incremento contador" se
coloca una instruccin que permite modificar el valor de la variable que hace de
contador (para permitir que alguna vez la condicin sea falsa)
Cuando el ciclo comienza, antes de dar la primera vuelta, la variable del for toma el
valor indicado en la seccin de de "inicializacin contador". Inmediatamente se verifica,
en forma automtica, si la condicin es verdadera. En caso de serlo se ejecuta el
bloque de operaciones del ciclo, y al finalizar el mismo se ejecuta la instruccin que se
haya
colocado
en
la
tercer
seccin.
Seguidamente, se vuelve a controlar el valor de la condicin, y as prosigue hasta que
dicha condicin entregue un falso.
Si conocemos la cantidad de veces que se repite el bloque es muy sencillo emplear un
for, por ejemplo si queremo que se repita 50 veces el bloque de instrucciones puede
hacerse as:
La variable del for puede tener cualquier nombre. En este ejemplo se la ha definido con
el
nombre
f.
Analicemos el ejemplo:
- La variable f toma inicialmente el valor 1.
- Se controla automticamente el valor de la condicin: como f
vale 1 y esto es menor
que 50, la condicin da verdadero.
Como
la
condicin
fue
verdadera,
se
ejecutan
la/s
operacin/es.
- Al finalizar de ejecutarlas, se retorna a la instruccin f++,
por lo que la
variable f se incrementa en uno.
- Se vuelve a controlar (automticamente) si f es menor o igual
a 50.
Como ahora su valor es 2, se ejecuta nuevamente el bloque de
instrucciones e
incrementa nuevamente la variable del for al terminar el mismo.
- El proceso se repetir hasta que la variable f sea
incrementada al valor 51.
En este momento la condicin ser falsa, y el ciclo se detendr.
La variable f PUEDE ser modificada dentro del bloque de operaciones del for, aunque
esto podra causar problemas de lgica si el programador es inexperto.
La variable f puede ser inicializada en cualquier valor y finalizar en cualquier valor.
Adems, no es obligatorio que la instruccin de modificacin sea un incremento del tipo
contador
(f++).
Cualquier instruccin que modifique el valor de la variable es vlida. Si por ejemplo se
escribe f=f+2 en lugar de f++, el valor de f ser incrementado de a 2 en cada vuelta, y
no de a 1. En este caso, esto significar que el ciclo no efectuar las 50 vueltas sino
slo 25.
Problema 1:
Realizar un programa que imprima en pantalla los nmeros del 1 al 100.
Diagrama de flujo:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor1
{
class Program
{
static void Main(string[] args)
{
int f;
for(f=1;f<=100;f++)
{
Console.Write(f);
Console.Write("-");
}
Console.ReadKey();
}
}
}
Problema 2:
: 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. Este problema ya lo
desarrollamos, lo resolveremos empleando la estructura for.
Diagrama de flujo:
En este caso, a la variable del for (f) slo se la requiere para que se repita el bloque de
instrucciones 10 veces.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor2
{
class Program
{
static void Main(string[] args)
{
int suma,f,valor,promedio;
string linea;
suma=0;
for(f=1;f<=10;f++)
{
Console.Write("Ingrese valor:");
linea=Console.ReadLine();
valor=int.Parse(linea);
suma=suma+valor;
}
Console.Write("La suma es:");
Console.WriteLine(suma);
promedio=suma/10;
Console.Write("El promedio es:");
Console.Write(promedio);
Console.ReadKey();
}
}
}
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:
Escribir un programa que lea 10 notas de alumnos y nos informe cuntos tienen notas
mayores o iguales a 7 y cuntos menores.
Para resolver este problema se requieren tres contadores:
aprobados (Cuenta la cantidad de alumnos aprobados)
reprobados (Cuenta la cantidad de reprobados)
f (es el contador del for)
Dentro de la estructura repetitiva debemos hacer la carga de la variable nota y verificar con una
estructura condicional si el contenido de la variable nota es mayor o igual a 7 para incrementar
el contador aprobados, en caso de que la condicin retorne falso debemos incrementar la
variable reprobados.
Diagrama de flujo:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
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++)
{
Console.Write("Ingrese la nota:");
linea = Console.ReadLine();
nota=int.Parse(linea);
if (nota>=7)
{
aprobados=aprobados+1;
}
else
{
reprobados=reprobados+1;
}
}
Console.Write("Cantidad de aprobados:");
Console.WriteLine(aprobados);
Console.Write("Cantidad de reprobados:");
Console.Write(reprobados);
Console.ReadKey();
}
}
}
Problema 4:
Escribir un programa que lea 10 nmeros enteros y luego muestre cuntos valores
ingresados fueron mltiplos de 3 y cuntos de 5. Debemos tener en cuenta que hay
nmeros que son mltiplos de 3 y de 5 a la vez.
Diagrama de flujo:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
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++)
{
Console.Write("Ingrese un valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
if (valor%3==0)
{
mul3=mul3+1;
}
if (valor%5==0)
{
mul5=mul5+1;
}
}
Console.Write("Cantidad de valores
ingresados mltiplos de 3:");
Console.WriteLine(mul3);
Console.Write("Cantidad de valores
ingresados mltiplos de 5:");
Console.Write(mul5);
Console.ReadKey();
}
}
}
Problema 5:
Escribir un programa que lea n nmeros enteros y calcule la cantidad de valores
mayores
o
iguales
a
1000.
Este tipo de problemas tambin se puede resolver empleando la estructura repetitiva
for. Lo primero que se hace es cargar una variable que indique la cantidad de valores a
ingresar. Dicha variable se carga antes de entrar a la estructura repetitiva for.
La estructura for permite que el valor inicial o final dependa de una variable cargada
previamente por teclado.
Diagrama de flujo:
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor5
{
class Program
{
static void Main(string[] args)
{
int cantidad,n,f,valor;
string linea;
cantidad=0;
Console.Write("Cuantos valores
ingresar:");
linea = Console.ReadLine();
n=int.Parse(linea);
for(f=1;f<=n;f++)
{
Console.Write("Ingrese el valor:");
linea = Console.ReadLine();
valor = int.Parse(linea);
if (valor>=1000)
{
cantidad=cantidad+1;
}
}
Console.Write("La cantidad de valores
ingresados mayores o iguales a 1000 son:");
Console.Write(cantidad);
Console.ReadKey();
}
}
}
Problemas propuestos
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor6
{
class Program
{
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor7
{
class Program
{
static void Main(string[] args)
{
int f,valor,suma;
string linea;
suma=0;
for(f=1;f<=10;f++)
{
Console.Write("Ingrese un valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
if (f>5)
{
suma=suma+valor;
}
}
Console.Write("La suma de los ltimos 5 valores
es:");
Console.Write(suma);
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor8
{
class Program
{
static void Main(string[] args)
{
int f;
for(f=5;f<=50;f=f+5)
{
Console.Write(f);
Console.Write("-");
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaFor9
{
class Program
{
static void Main(string[] args)
{
int f,valor;
string linea;
Console.Write("Ingrese un valor entre 1 y 10:");
linea = Console.ReadLine();
valor=int.Parse(linea);
for(f=valor;f<=valor*12;f=f+valor)
{
Console.Write(f);
Console.Write("-");
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
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;
Console.Write("Ingrese la cantidad de tringulos:");
linea = Console.ReadLine();
n=int.Parse(linea);
for(f=1;f<=n;f++)
{
Console.Write("Ingrese lado 1:");
linea = Console.ReadLine();
lado1=int.Parse(linea);
Console.Write("Ingrese lado 2:");
linea = Console.ReadLine();
lado2 = int.Parse(linea);
Console.Write("Ingrese lado 3:");
linea = Console.ReadLine();
lado3 = int.Parse(linea);
if (lado1==lado2 && lado1==lado3)
{
Console.WriteLine("Es un tringulo
equilatero.");
cant1++;
}
else
{
if (lado1==lado2 || lado1==lado3 ||
lado2==lado3)
{
Console.WriteLine("Es un tringulo
issceles.");
cant2++;
}
else
{
cant3++;
Console.WriteLine("Es un tringulo
escaleno.");
}
}
}
Console.Write("Cantidad de tringulos
equilateros:");
Console.WriteLine(cant1);
Console.Write("Cantidad de tringulos issceles:");
Console.WriteLine(cant2);
Console.Write("Cantidad de tringulos escalenos:");
Console.WriteLine(cant3);
if (cant1<cant2 && cant1<cant3)
{
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
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;
Console.Write("Cantidad de puntos:");
linea = Console.ReadLine();
n=int.Parse(linea);
for(f=1;f<=n;f++)
{
Console.Write("Ingrese coordenada x:");
linea = Console.ReadLine();
x=int.Parse(linea);
Console.Write("Ingrese coordenada y:");
linea = Console.ReadLine();
y=int.Parse(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++;
}
}
}
}
}
Console.Write("Cantidad de
cuadrante:");
Console.WriteLine(cant1);
Console.Write("Cantidad de
cuadrante:");
Console.WriteLine(cant2);
Console.Write("Cantidad de
cuadrante:");
Console.WriteLine(cant3);
Console.Write("Cantidad de
cuadrante:");
Console.WriteLine(cant4);
Console.ReadKey();
}
}
}
puntos en el primer
puntos en el segundo
puntos en el tercer
puntos en el cuarto
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
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++)
{
Console.Write("Ingrese valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
if (valor<0)
{
negativos++;
}
else
{
if (valor>0)
{
positivos++;
}
}
if (valor%15==0)
{
mult15++;
}
if (valor%2==0)
{
sumapares=sumapares+valor;
}
}
Console.Write("Cantidad de valores negativos:");
Console.WriteLine(negativos);
Console.Write("Cantidad de valores positivos:");
Console.WriteLine(positivos);
Console.Write("Cantidad de valores mltiplos de
15:");
Console.WriteLine(mult15);
Console.Write("Suma de los valores pares:");
Console.WriteLine(sumapares);
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
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++)
{
Console.Write("Ingrese edad:");
linea = Console.ReadLine();
edad=int.Parse(linea);
suma1=suma1+edad;
}
pro1=suma1/50;
Console.Write("Promedio de edades del turno
maana:");
Console.WriteLine(pro1);
for(f=1;f<=60;f++)
{
Console.Write("Ingrese edad:");
linea = Console.ReadLine();
edad = int.Parse(linea) ;
suma2=suma2+edad;
}
pro2=suma2/60;
Console.Write("Promedio de edades del turno
tarde:");
Console.WriteLine(pro2);
for(f=1;f<=110;f++)
{
Console.Write("Ingrese edad:");
linea = Console.ReadLine();
edad=int.Parse(linea);
suma3=suma3+edad;
}
pro3=suma3/110;
Console.Write("Promedio de edades del turno
noche:");
Console.WriteLine(pro3);
if (pro1<pro2 && pro1<pro3)
{
Console.Write("El turno maana tiene un promedio
menor de edades.");
}
else
{
if (pro2<pro3)
{
Console.Write("El turno tarde tiene un
promedio menor de edades.");
}
else
{
Console.Write("El turno noche tiene un
promedio menor de edades.");
}
}
Console.ReadKey();
}
}
}
bloque.
Esta estructura repetitiva se utiliza cuando conocemos de antemano que por lo
menos
una
vez
se
ejecutar
el
bloque
repetitivo.
La condicin de la estructura est abajo del bloque a repetir, a diferencia del while o
del for que est en la parte superior.
Representacin grfica:
Problema 1:
Escribir un programa que solicite la carga de un nmero entre 0 y 999, y nos
muestre un mensaje de cuntos dgitos tiene el mismo. Finalizar el programa
cuando se cargue el valor 0.
Diagrama de flujo:
No hay que confundir los rombos de las estructuras condicionales con los de las
estructuras
repetitivas
do
while.
En este problema por lo menos se carga un valor. Si se carga un valor mayor o
igual a 100 se trata de un nmero de tres cifras, si es mayor o igual a 10 se trata de
un valor de dos dgitos, en caso contrario se trata de un valor de un dgito. Este
bloque se repite hasta que se ingresa en la variable valor el nmero 0 con lo que la
condicin de la estructura do while retorna falso y sale del bloque repetitivo
finalizando el programa.
Programa:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EstructuraRepetitivaDoWhile1
{
class Program
{
static void Main(string[] args)
{
int valor;
string linea;
do {
Console.Write("Ingrese un valor
entre 0 y 999 (0 finaliza):");
linea = Console.ReadLine();
valor=int.Parse(linea);
if (valor>=100)
{
Console.WriteLine("Tiene 3
dgitos.");
}
else
{
if (valor>=10)
{
Console.WriteLine("Tiene 2
dgitos.");
}
else
{
Console.WriteLine("Tiene 1
dgito.");
}
}
} while (valor!=0);
}
}
}
Problema 2:
Escribir un programa que solicite la carga de nmeros por teclado, obtener su
promedio. Finalizar la carga de valores cuando se cargue el valor 0.
Cuando la finalizacin depende de algn valor ingresado por el operador conviene
el empleo de la estructura do while, por lo menos se cargar un valor (en el caso
ms extremo se carga 0, que indica la finalizacin de la carga de valores)
Diagrama de flujo:
Es
importante
analizar
este
diagrama
de
flujo.
Definimos un contador cant que cuenta la cantidad de valores ingresados por el
operador
(no
lo
incrementa
si
ingresamos
0)
El valor 0 no es parte de la serie de valores que se deben sumar.
Definimos el acumulador suma que almacena todos los valores ingresados por
teclado.
La estructura repetitiva do while se repite hasta que ingresamos el valor 0. Con
dicho valor la condicin del ciclo retorna falso y contina con el flujo del diagrama.
Disponemos por ltimo una estructura condicional para el caso que el operador
cargue nicamente un 0 y por lo tanto no podemos calcular el promedio ya que no
existe
la
divisin
por
0.
En caso que el contador cant tenga un valor distinto a 0 el promedio se obtiene
dividiendo el acumulador suma por el contador cant que tiene la cantidad de valores
ingresados antes de introducir el 0.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaDoWhile2
{
class Program
{
static void Main(string[] args)
{
int suma,cant,valor,promedio;
string linea;
suma=0;
cant=0;
do {
Console.Write("Ingrese un valor (0
para finalizar):");
linea = Console.ReadLine();
valor=int.Parse(linea);
if (valor!=0) {
suma=suma+valor;
cant++;
}
} while (valor!=0);
if (cant!=0) {
promedio=suma/cant;
Console.Write("El promedio de los
valores ingresados es:");
Console.Write(promedio);
} else {
Console.Write("No se ingresaron
valores.");
}
Console.ReadLine();
}
}
}
El contador cant DEBE inicializarse antes del ciclo, lo mismo que el acumulador
suma. El promedio se calcula siempre y cuando el contador cant sea distinto a 0.
Problema 3:
Realizar un programa que permita ingresar el peso (en kilogramos) de piezas. El
proceso termina cuando ingresamos el valor 0. Se debe informar:
a) Cuntas piezas tienen un peso entre 9.8 Kg. y 10.2 Kg.?, cuntas con ms de
10.2
Kg.?
y
cuntas
con
menos
de
9.8
Kg.?
b) La cantidad total de piezas procesadas.
Diagrama de flujo:
valor no se lo considera un peso menor a 9.8 Kg., sino que indica que ha finalizado
la carga de valores por teclado.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaDoWhile3
{
class Program
{
static void Main(string[] args)
{
int cant1,cant2,cant3,suma;
float peso;
string linea;
cant1=0;
cant2=0;
cant3=0;
do {
Console.Write("Ingrese el peso de
la pieza (0 pera finalizar):");
linea = Console.ReadLine();
peso=float.Parse(linea);
if (peso>10.2)
{
cant1++;
}
else
{
if (peso>=9.8)
{
cant2++;
}
else
{
if (peso>0)
{
cant3++;
}
}
}
} while(peso!=0);
suma=cant1+cant2+cant3;
Console.Write("Piezas aptas:");
Console.WriteLine(cant2);
Console.Write("Piezas con un peso
superior a 10.2:");
Console.WriteLine(cant1);
Console.Write("Piezas con un peso
inferior a 9.8:");
Console.WriteLine(cant3);
Console.ReadLine();
}
}
}
Problemas propuestos
1. Realizar un programa que acumule (sume) valores ingresados por teclado
hasta ingresar el 9999 (no sumar dicho valor, indica que ha finalizado la
carga). Imprimir el valor acumulado e informar si dicho valor es cero, mayor a
cero o menor a cero.
2. En un banco se procesan datos de las cuentas corrientes de sus clientes. De
cada cuenta corriente se conoce: nmero de cuenta y saldo actual. El ingreso
de datos debe finalizar al ingresar un valor negativo en el nmero de cuenta.
Se pide confeccionar un programa que lea los datos de las cuentas corrientes
e
informe:
a)De cada cuenta: nmero de cuenta y estado de la cuenta segn su saldo,
sabiendo que:
3. Estado de la cuenta
'Acreedor' si el saldo es >0.
4.
'Deudor' si el saldo es <0.
5.
'Nulo' si el saldo es =0.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaDoWhile4
{
class Program
{
static void Main(string[] args)
{
int suma,valor;
string linea;
suma=0;
do {
Console.Write("Ingrese un valor:");
linea = Console.ReadLine();
valor=int.Parse(linea);
if (valor!=9999)
{
suma=suma+valor;
}
}while (valor!=9999);
Console.Write("El valor acumulado es ");
Console.WriteLine(suma);
if (suma==0)
{
Console.WriteLine("El valor acumulado es
cero.");
}
else
{
if (suma>0)
{
Console.WriteLine("El valor acumulado es
positivo.");
}
else
{
Console.WriteLine("El valor acumulado es
negativo");
}
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EstructuraRepetitivaDoWhile5
{
class Program
{
static void Main(string[] args)
{
int cuenta;
float saldo,suma;
string linea;
suma=0;
do {
Console.Write("Ingrese nmero de cuenta:");
linea = Console.ReadLine();
cuenta=int.Parse(linea);
if (cuenta>=0)
{
Console.Write("Ingrese saldo:");
linea = Console.ReadLine();
saldo=float.Parse(linea);
if (saldo>0)
{
Console.WriteLine("Saldo Acreedor.");
suma=suma+saldo;
}
else
{
if (saldo<0)
{
Console.WriteLine("Saldo Deudor.");
}
else
{
Console.WriteLine("Saldo Nulo.");
}
}
}
} while(cuenta>=0);
Problema 1:
Solicitar el ingreso del nombre y edad de dos personas. Mostrar el nombre de la
persona con mayor edad.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CadenaDeCaracteres1
{
class Program
{
static void Main(string[] args)
{
String nombre1,nombre2;
int edad1,edad2;
String linea;
Console.Write("Ingrese el nombre:");
nombre1=Console.ReadLine();
Console.Write("Ingrese edad:");
linea=Console.ReadLine();
edad1=int.Parse(linea);
Console.Write("Ingrese el nombre:");
nombre2=Console.ReadLine();
Console.Write("Ingrese edad:");
linea=Console.ReadLine();
edad2=int.Parse(linea);
Console.Write("La persona de mayor edad
es:");
if (edad1>edad2)
{
Console.Write(nombre1);
}
else
{
Console.Write(nombre2);
}
Console.ReadKey();
}
}
}
Para almacenar un nombre debemos definir una variable de tipo string y su ingreso
por teclado se hace llamando al mtodo ReadLine del objeto Console:
nombre1=Console.ReadLine();
No tenemos que hacer ninguna conversin como sucede cuando cargamos un valor
de tipo int o float.
Problema 2:
Solicitar el ingreso del apellido, nombre y edad de dos personas. Mostrar el nombre
de la persona con mayor edad. Realizar la carga del apellido y nombre en una
variable de tipo string.
Programa:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace CadenaDeCaracteres2
{
class Program
{
static void Main(string[] args)
{
string apenom1,apenom2;
int edad1,edad2;
string linea;
Console.Write("Ingrese el apellido y el
nombre:");
apenom1=Console.ReadLine();
Console.Write("Ingrese edad:");
linea = Console.ReadLine();
edad1=int.Parse(linea);
Console.Write("Ingrese el apellido y el
nombre:");
apenom2=Console.ReadLine();
Console.Write("Ingrese edad:");
linea = Console.ReadLine();
edad2=int.Parse(linea);
Console.Write("La persona de mayor edad
es:");
if (edad1>edad2) {
Console.Write(apenom1);
} else {
Console.Write(apenom2);
}
Console.ReadKey();
}
}
}
Problema 3:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace CadenaDeCaracteres3
{
class Program
{
static void Main(string[] args)
{
string apellido1,apellido2;
Console.Write("Ingrese primer
apellido:");
apellido1=Console.ReadLine();
Console.Write("Ingrese segundo
apellido:");
apellido2=Console.ReadLine();
if (apellido1==apellido2)
{
Console.Write("Los apellidos son
iguales");
}
else
{
Console.Write("Los apellidos son
distintos");
}
Console.ReadKey();
}
}
}
Para comparar si el contenido de dos string son iguales se utiliza el operador ==
como
si
se
estuvieran
comparando
dos
enteros.
La condicin se verifica verdadero si los contenidos de los dos string son
Problema 1:
Confeccionar una clase que permita carga el nombre y la edad de una persona.
Mostrar los datos cargados. Imprimir un mensaje si es mayor de edad (edad>=18)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaClase1
{
class Persona
{
private string nombre;
private int edad;
per1.Inicializar();
per1.Imprimir();
per1.EsMayorEdad();
}
}
}
}
El nombre de la clase debe hacer referencia al concepto (en este caso la hemos
llamado Persona):
class Persona
En el mtodo inicializar (que ser el primero que deberemos llamar desde la main)
cargamos por teclado los atributos nombre y edad. Como podemos ver el mtodo
inicializar puede hacer acceso a dos atributos de la clase Persona.
El segundo mtodo tiene por objetivo imprimir el contenido de los atributos nombre
y edad (los datos de los atributos se cargaron al ejecutarse previamente el mtodo
inicializar:
Console.Write("Nombre:");
Console.WriteLine(nombre);
Console.Write("Edad:");
Console.WriteLine(edad);
creacin
del
objeto
Problema 2:
Desarrollar un programa que cargue los lados de un tringulo e implemente los
siguientes mtodos: inicializar los atributos, imprimir el valor del lado mayor y otro
mtodo que muestre si es equiltero o no.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaClase2
{
class Triangulo
{
private int lado1, lado2, lado3;
public void Inicializar()
{
string linea;
Console.Write("Medida lado 1:");
linea = Console.ReadLine();
lado1 = int.Parse(linea);
Console.Write("Medida lado 2:");
linea = Console.ReadLine();
lado2 = int.Parse(linea);
Console.Write("Medida lado 3:");
linea = Console.ReadLine();
lado3 = int.Parse(linea);
}
public void LadoMayor()
{
Console.Write("Lado mayor:");
if (lado1 > lado2 && lado1 > lado3)
{
Console.WriteLine(lado1);
}
else
{
if (lado2 > lado3)
{
Console.WriteLine(lado2);
}
else
{
Console.WriteLine(lado3);
}
}
}
public void EsEquilatero()
{
if (lado1==lado2 && lado1==lado3)
{
Console.Write("Es un tringulo
equiltero");
}
else
{
Console.Write("No es un tringulo
equiltero");
}
}
Problema 3:
Desarrollar una clase que represente un punto en el plano y tenga los siguientes
mtodos: cargar los valores de x e y, imprimir en que cuadrante se encuentra dicho
punto (concepto matemtico, primer cuadrante si x e y son positivas, si x<0 e y>0
segundo cuadrante, etc.)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaClase3
{
class Punto
{
private int x, y;
public void Inicializar()
{
string linea;
Console.Write("Ingrese coordenada x
:");
linea = Console.ReadLine();
x = int.Parse(linea);
Console.Write("Ingrese coordenada y
:");
linea = Console.ReadLine();
y = int.Parse(linea);
}
void ImprimirCuadrante()
{
if (x>0 && y>0)
{
Console.Write("Se encuentra en el
primer cuadrante.");
}
else
{
if (x<0 && y>0)
{
Console.Write("Se encuentra en
el segundo cuadrante.");
}
else
{
if (x<0 && y<0)
{
Console.Write("Se encuentra
en el tercer cuadrante.");
}
else
{
if (x>0 && y<0)
{
Console.Write("Se
encuentra en el cuarto cuadrante.");
}
else
{
Console.Write("El punto
no est en un cuadrante.");
}
}
}
}
Console.ReadKey();
}
static void Main(string[] args)
{
Punto punto1 = new Punto();
punto1.Inicializar();
punto1.ImprimirCuadrante();
}
}
}
Definimos dos atributos :
private int x, y;
encuentra
en
el
cuarto
cuadrante.");
}
else
{
Console.Write("El
punto
no
est
en
un
cuadrante.");
}
}
}
}
Console.ReadKey();
}
Problema 4:
Desarrollar una clase que represente un Cuadrado y tenga los siguientes mtodos:
cargar el valor de su lado, imprimir su permetro y su superficie.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaClase4
{
class Cuadrado
{
private int lado;
public void Inicializar()
{
Console.Write("Ingrese el valor del
lado:");
string linea;
linea = Console.ReadLine();
lado=int.Parse(linea);
}
public void ImprimirPerimetro()
{
int perimetro;
perimetro=lado*4;
Console.WriteLine("El permetro
es:"+perimetro);
}
public void ImprimirSuperficie()
{
int superficie;
superficie=lado*lado;
Console.WriteLine("La superficie
es:"+superficie);
}
static void Main(string[] args)
{
Cuadrado cuadrado1 = new Cuadrado();
cuadrado1.Inicializar();
cuadrado1.ImprimirPerimetro();
cuadrado1.ImprimirSuperficie();
Console.ReadKey();
}
}
}
En este problema es interesante ver como no definimos dos atributos donde se
almacenan la superficie y el permetro del cuadrado, esto debido a que solo estos
datos se los requiere en el mtodo donde se imprimen:
public void ImprimirPerimetro()
{
int perimetro;
perimetro=lado*4;
Console.WriteLine("El permetro es:"+perimetro);
}
Problemas propuestos
1. Confeccionar una clase que represente un empleado. Definir como atributos
su nombre y su sueldo. Confeccionar los mtodos para la carga, otro para
imprimir sus datos y por ltimo uno que imprima un mensaje si debe pagar
impuestos (si el sueldo supera a 3000)
2. Implementar la clase operaciones. Se deben cargar dos valores enteros,
calcular su suma, resta, multiplicacin y divisin, cada una en un mtodo,
imprimir dichos resultados.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaClase5
{
class Empleado
{
string nombre;
float sueldo;
public void Inicializar()
{
string linea;
Console.Write("Ingrese el nombre del empleado:");
nombre = Console.ReadLine();
Console.Write("Ingrese su sueldo:");
linea = Console.ReadLine();
sueldo=float.Parse(linea);
}
public void PagaImpuestos()
{
if (sueldo>3000)
{
Console.WriteLine("Debe abonar impuestos");
}
else
{
Console.WriteLine("No paga impuestos");
}
Console.ReadKey();
}
static void Main(string[] args)
{
Empleado empleado1= new Empleado();
empleado1.Inicializar();
empleado1.PagaImpuestos();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaClase5
{
class Operaciones
{
private int valor1, valor2;
public void Inicializar()
{
string linea;
Console.Write("Ingrese primer valor:");
linea=Console.ReadLine();
valor1=int.Parse(linea);
Console.Write("Ingrese segundo valor:");
linea = Console.ReadLine();
valor2=int.Parse(linea);
}
public void Sumar()
{
int suma;
suma=valor1+valor2;
Console.WriteLine("La suma es:"+suma);
}
public void Restar()
{
int resta;
resta=valor1-valor2;
Console.WriteLine("La resta es:"+resta);
}
public void Multiplicar()
{
int multiplicacion;
multiplicacion=valor1*valor2;
Console.WriteLine("La multiplicacin
es:"+multiplicacion);
}
public void dividir()
{
int division;
division = valor1 / valor2;
Console.WriteLine("La divisin es:" + division);
}
static void Main(string[] args)
{
Operaciones operacion1 = new Operaciones();
operacion1.Inicializar();
operacion1.Sumar();
operacion1.Restar();
operacion1.Multiplicar();
operacion1.dividir();
Console.ReadKey();
}
}
Los parmetros los podemos imaginar como variables locales al mtodo, pero su
valor se inicializa con datos que llegan cuando lo llamamos.
Problema 1:
Confeccionar una clase que permita ingresar valores enteros por teclado y nos
muestre la tabla de multiplicar de dicho valor. Finalizar el programa al ingresar el -1.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Tabla
{
class TablaMultiplicar
{
public void CargarValor()
{
int valor;
string linea;
do
{
Console.Write("Ingrese un valor (-1
para finalizar):");
linea = Console.ReadLine();
valor = int.Parse(linea);
if (valor != -1)
{
Calcular(valor);
}
} while (valor != -1);
}
public void Calcular(int v)
{
for(int f=v;f<=v*10;f=f+v)
{
Console.Write(f+"-");
}
Console.WriteLine();
}
static void Main(string[] args)
{
TablaMultiplicar tm = new
TablaMultiplicar();
tm.CargarValor();
}
}
}
En esta clase no hemos definido ningn atributo.
El mtodo Calcular recibe un parmetro de tipo entero, luego lo utilizamos dentro
del mtodo para mostrar la tabla de multiplicar de dicho valor, para esto
inicializamos la variable f con el valor que llega en el parmetro. Luego de cada
ejecucin del for incrementamos el contador f con el valor de v.
public void Calcular(int v)
{
for(int f=v;f<=v*10;f=f+v)
{
Console.Write(f+"-");
}
Console.WriteLine();
}
Cuando un mtodo retorna un dato en vez de indicar la palabra clave void previo al
nombre del mtodo indicamos el tipo de dato que retorna. Luego dentro del
algoritmo en el momento que queremos que finalice el mismo y retorne el dato
empleamos la palabra clave return con el valor respectivo.
Problema 2:
Confeccionar una clase que permita ingresar tres valores por teclado. Luego
mostrar el mayor y el menor.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace EspacioMayorMenor
{
class MayorMenor
{
public void cargarValores()
{
string linea;
Console.Write("Ingrese primer valor:");
linea = Console.ReadLine();
int valor1 = int.Parse(linea);
Console.Write("Ingrese segundo
valor:");
linea = Console.ReadLine();
int valor2 = int.Parse(linea);
Console.Write("Ingrese tercer valor:");
linea = Console.ReadLine();
int valor3 = int.Parse(linea);
int mayor, menor;
mayor = CalcularMayor(valor1, valor2,
valor3);
menor = CalcularMenor(valor1, valor2,
valor3);
Console.WriteLine("El valor mayor de
los tres es:" + mayor);
Console.WriteLine("El valor menor de
los tres es:" + menor);
}
{
m = v3;
}
}
return m;
}
static void Main(string[] args)
{
MayorMenor mm = new MayorMenor();
mm.cargarValores();
Console.ReadKey();
}
}
}
Si vemos la sintaxis que calcula el mayor de tres valores enteros es similar al
algoritmo visto en conceptos anteriores:
Lo primero que podemos observar que el mtodo retorna un entero y recibe tres
parmetros:
public int CalcularMayor(int v1, int v2, int v3)
Dentro del mtodo verificamos cual de los tres parmetros almacena un valor
mayor, a este valor lo almacenamos en una variable local llamada "m", al valor
almacenado en esta variable lo retornamos al final con un return.
La llamada al mtodo calcularMayor lo hacemos desde dentro del mtodo
CargarCalores:
mayor=CalcularMayor(valor1,valor2,valor3);
Problema 1:
Se
desea
guardar
los
sueldos
de
5
operarios.
Segn lo conocido deberamos definir 5 variables si queremos tener en un cierto
momento
los
5
sueldos
almacenados
en
memoria.
Empleando un vector solo se requiere definir un nico nombre y accedemos a cada
elemento por medio del subndice.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector1
{
class PruebaVector1
{
private int[] sueldos;
public void Cargar()
{
sueldos = new int[5];
for (int f = 0; f < 5; f++)
{
Console.Write("Ingrese valor de la
componente:");
String linea;
linea = Console.ReadLine();
sueldos[f] = int.Parse(linea);
}
}
Lo mas comn es utilizar una estructura repetitiva for para recorrer cada
componente del vector.
Utilizar el for nos reduce la cantidad de cdigo, si no utilizo un for debera en forma
secuencial implementar el siguiente cdigo:
string linea;
Console.Write("Ingrese valor
linea=Console.ReadLine();
sueldos[0]=int.Parse(linea);
Console.Write("Ingrese valor
linea=Console.ReadLine();
sueldos[1]=int.Parse(linea);
Console.Write("Ingrese valor
linea=Console.ReadLine();
sueldos[2]=int.Parse(linea);
Console.Write("Ingrese valor
linea=Console.ReadLine();
sueldos[3]=int.Parse(linea);
Console.Write("Ingrese valor
linea=Console.ReadLine();
sueldos[4]=int.Parse(linea);
de la componente:");
de la componente:");
de la componente:");
de la componente:");
de la componente:");
Siempre que queremos acceder a una componente del vector debemos indicar
entre corchetes la componente, dicho valor comienza a numerarse en cero y
continua hasta un nmero menos del tamao del vector, en nuestro caso creamos
el vector con 5 elementos:
sueldos = new int[5];
Problema 2:
Definir un vector de 5 componentes de tipo float que representen las alturas de 5
personas.
Obtener el promedio de las mismas. Contar cuntas personas son ms altas que el
promedio y cuntas ms bajas.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector2
{
class PruebaVector2
{
private float[] alturas;
private float promedio;
public void Cargar()
{
alturas=new float[5];
for (int f = 0; f < 5; f++)
{
Console.Write("Ingrese la altura de
la persona:");
string linea = Console.ReadLine();
alturas[f] = float.Parse(linea);
}
}
public void CalcularPromedio()
{
float suma;
suma=0;
for(int f=0; f < 5; f++)
{
suma=suma+alturas[f];
}
promedio=suma/5;
Console.WriteLine("Promedio de
alturas:"+promedio);
}
Por ltimo en un tercer mtodo comparamos cada componente del vector con el
atributo promedio, si el valor almacenado supera al promedio incrementamos un
contador en caso que sea menor al promedio incrementamos otro contador:
public void MayoresMenores()
{
int may,men;
may=0;
men=0;
for(int f = 0; f < 5; f++)
{
if (alturas[f] > promedio)
{
may++;
}
else
{
if (alturas[f] < promedio)
{
men++;
}
}
}
Console.WriteLine("Cantidad
de
promedio:"+may);
Console.WriteLine("Cantidad
de
promedio:"+men);
Console.ReadKey();
}
personas
mayores
al
personas
menores
al
Importante:
En este problema podemos observar una ventaja de tener almacenadas todas las
alturas de las personas. Si no conociramos los vectores tenemos que cargar otra
vez las alturas por teclado para compararlas con el promedio.
Mientras el programa est en ejecucin tenemos el vector alturas a nuestra
disposicin. Es importante tener en cuenta que cuando finaliza la ejecucin del
programa se pierde el contenido de todas las variables (simples y vectores)
Problema 3:
Una empresa tiene dos turnos (maana y tarde) en los que trabajan 8 empleados (4
por
la
maana
y
4
por
la
tarde)
Confeccionar un programa que permita almacenar los sueldos de los empleados
agrupados
por
turno.
Imprimir los gastos en sueldos de cada turno.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector3
{
class PruebaVector3
{
private float[] turnoMan;
private float[] turnoTar;
public void Cargar()
{
string linea;
turnoMan=new float[4];
turnoTar=new float[4];
Console.WriteLine("Sueldos de empleados
del turno de la maana.");
for(int f = 0; f < 4; f++)
{
Console.Write("Ingrese sueldo:");
linea = Console.ReadLine();
turnoMan[f]=float.Parse(linea);
}
Console.WriteLine("Sueldos de empleados
del turno de la tarde.");
for(int f = 0; f < 4; f++)
{
Console.Write("Ingrese sueldo:");
linea = Console.ReadLine();
turnoTar[f]=float.Parse(linea);
}
}
public void CalcularGastos()
{
float man=0;
float tar=0;
for(int f = 0; f < 4; f++)
{
man=man+turnoMan[f];
tar=tar+turnoTar[f];
}
Console.WriteLine("Total de gastos del
turno de la maana:"+man);
Console.WriteLine("Total de gastos del
turno de la tarde:"+tar);
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector3 pv = new PruebaVector3();
pv.Cargar();
pv.CalcularGastos();
}
}
}
Definimos dos atributos de tipo vector donde almacenaremos los sueldos de los
empleados de cada turno:
private float[] turnoMan;
private float[] turnoTar;
de
empleados
del
turno
de
la
maana.");
for(int f = 0; f < 4; f++)
{
Console.Write("Ingrese sueldo:");
linea = Console.ReadLine();
turnoMan[f]=float.Parse(linea);
}
Console.WriteLine("Sueldos de empleados del turno de la tarde.");
for(int f = 0; f < 4; f++)
{
Console.Write("Ingrese sueldo:");
linea = Console.ReadLine();
turnoTar[f]=float.Parse(linea);
}
Problemas propuestos
1. Desarrollar un programa que permita ingresar un vector de 8 elementos, e
informe:
El
valor
acumulado
de
todos
los
elementos
del
vector.
El valor acumulado de los elementos del vector que sean mayores a 36.
Cantidad de valores mayores a 50.
2. Realizar un programa que pida la carga de dos vectores numricos enteros
de 4 elementos. Obtener la suma de los dos vectores, dicho resultado
guardarlo en un tercer vector del mismo tamao. Sumar componente a
componente.
3. Se tienen las notas del primer parcial de los alumnos de dos cursos, el curso
A
y
el
curso
B,
cada
curso
cuenta
con
5
alumnos.
Realizar un programa que muestre el curso que obtuvo el mayor promedio
general.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector4
{
class PruebaVector4
{
private int[] vec;
public void Cargar()
{
vec=new int[8];
for(int f = 0; f < 8; f++)
{
Console.Write("Ingrese elemento:");
string linea;
linea = Console.ReadLine();
vec[f]=int.Parse(linea);
}
}
public void AcumularElementos()
{
int suma=0;
for(int f = 0; f < 8; f++)
{
suma=suma+vec[f];
}
Console.WriteLine("La suma de los 8 elementos
es:"+suma);
}
public void AcumularMayores36()
{
int suma=0;
for(int f = 0; f < 8; f++)
{
if (vec[f] > 36)
{
suma=suma+vec[f];
}
}
Console.WriteLine("La suma de los elementos mayores
a 36 es:"+suma);
}
public void CantidadMayores50()
{
int cant=0;
for(int f = 0; f < 8; f++)
{
if (vec[f] > 50)
{
cant++;
}
}
Console.WriteLine("La cantidad de valores mayores a
50 es:"+cant);
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector4 pv = new PruebaVector4();
pv.Cargar();
pv.AcumularElementos();
pv.AcumularMayores36();
pv.CantidadMayores50();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector5
{
class PruebaVector5
{
private int[] vec1;
private int[] vec2;
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector6
{
class PruebaVector6
{
private int[] cursoa;
private int[] cursob;
private int[] vecSuma;
public void Cargar()
{
cursoa=new int[5];
cursob=new int[5];
Console.WriteLine("Carga de notas del curso A");
for(int f = 0; f < 5; f++)
{
Console.Write("Ingrese nota:");
string linea;
linea = Console.ReadLine();
cursoa[f]=int.Parse(linea);
}
Console.WriteLine("Carga del notas del curso B");
for(int f = 0; f < 5; f++)
{
Console.Write("Ingrese nota:");
string linea;
linea = Console.ReadLine();
cursob[f] =int.Parse(linea);
}
}
public void CalcularPromedios()
{
int suma1=0;
int suma2=0;
for(int f=0;f<5;f++)
{
suma1=suma1+cursoa[f];
suma2=suma2+cursob[f];
}
int promedioa=suma1/5;
int promediob=suma2/5;
if (promedioa>promediob)
{
Console.WriteLine("El curso A tiene un promedio
mayor.");
}
else
{
Console.WriteLine("El curso B tiene un promedio
mayor.");
}
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector6 pv = new PruebaVector6();
pv.Cargar();
pv.CalcularPromedios();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector7
{
class PruebaVector7
{
private int[] vec;
public void Cargar()
{
vec=new int[10];
for(int f = 0; f < 10; f++)
{
Console.Write("Ingrese elemento:");
string linea = Console.ReadLine();
vec[f]=int.Parse(linea);
}
}
public void VerificarOrdenado()
{
int orden=1;
for(int f = 0; f < 9; f++)
{
if (vec[f+1] < vec[f])
{
orden=0;
}
}
if (orden==1)
{
Console.WriteLine("Esta ordenado de menor a
mayor");
}
else
{
Console.WriteLine("No esta ordenado de menor a
mayor");
}
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector7 pv = new PruebaVector7();
pv.Cargar();
pv.VerificarOrdenado();
}
}
}
}
Como vemos el for se repite mientras el contador f vale menos de 5. Este estructura
repetitiva
es
idntica
cada
vez
que
recorremos
el
vector.
Que pasa ahora si cambiamos el tamao del vector cuando lo creamos:
sueldos=new int[7];
Con esto tenemos que cambiar todos los for que recorren dicho vector. Ahora veremos
que un vector al ser un objeto tiene una propiedad llamada Length que almacena su
tamao. Luego podemos modificar todos los for con la siguiente sintaxis:
for(int f=0;f<sueldos.Length;f++)
{
Console.Write("Ingrese valor de la componente:");
string linea;
linea=Console.ReadLine();
sueldos[f]=int.Parse(linea);
}
Tambin podemos pedir al usuario que indique el tamao del vector en tiempo de
ejecucin, en estos casos se hace imprescindible el empleo de la propiedad Length.
Problema 1:
Se desea almacenar los sueldos de operarios. Cuando se ejecuta el programa se debe
pedir la cantidad de sueldos a ingresar. Luego crear un vector con dicho tamao.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector8
{
class PruebaVector8
{
private int[] sueldos;
public void Cargar()
{
Console.Write("Cuantos sueldos
cargar:");
string linea;
linea=Console.ReadLine();
int cant=int.Parse(linea);
sueldos=new int[cant];
Problemas propuestos
1. Desarrollar un programa que permita ingresar un vector de n elementos, ingresar n por
teclado. Luego imprimir la suma de todos sus elementos
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector9
{
class PruebaVector9
{
private int[] vec;
public void Cargar()
{
Console.Write("Cuantos elementos tiene el vector:");
string linea=Console.ReadLine();
int n;
n=int.Parse(linea);
vec=new int[n];
for(int f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese elemento:");
linea=Console.ReadLine();
vec[f]=int.Parse(linea);
}
}
public void AcumularElementos()
{
int suma=0;
for(int f = 0; f < vec.Length; f++)
{
suma=suma+vec[f];
}
Console.WriteLine("La suma de los elementos
es:"+suma);
Console.ReadKey();
}
Problema 1:
Desarrollar un programa que permita cargar 5 nombres de personas y sus edades
respectivas. Luego de realizar la carga por teclado de todos los datos imprimir los
nombres de las personas mayores de edad (mayores o iguales a 18 aos)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector10
{
class PruebaVector10
{
private string[] nombres;
private int[] edades;
public void Cargar()
{
nombres=new string[5];
edades=new int[5];
for(int f=0;f < nombres.Length;f++)
{
Console.Write("Ingrese nombre:");
nombres[f]=Console.ReadLine();
Console.Write("Ingrese edad:");
string linea;
linea = Console.ReadLine();
edades[f]=int.Parse(linea);
}
}
public void MayoresEdad()
{
Console.WriteLine("Personas mayores de
edad.");
for(int f=0;f < nombres.Length;f++)
{
if (edades[f] >= 18)
{
Console.WriteLine(nombres[f]);
}
}
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector10 pv = new
PruebaVector10();
pv.Cargar();
pv.MayoresEdad();
}
}
}
Definimos los dos vectores:
private string[] nombres;
private int[] edades;
Problema 1:
Confeccionar un programa que permita cargar los nombres de 5 operarios y sus
sueldos respectivos. Mostrar el sueldo mayor y el nombre del operario.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector11
{
class PruebaVector11
{
private string[] nombres;
private float[] sueldos;
public void Cargar()
{
nombres=new string[5];
sueldos=new float[5];
for(int f=0;f < nombres.Length;f++)
{
Console.Write("Ingrese el nombre
del empleado:");
nombres[f] = Console.ReadLine();
Console.Write("Ingrese el
sueldo:");
string linea;
linea = Console.ReadLine();
sueldos[f]=float.Parse(linea);
}
}
public void MayorSueldo()
{
float mayor;
int pos;
mayor=sueldos[0];
pos=0;
for(int f=1;f < nombres.Length;f++)
{
if (sueldos[f] > mayor)
{
mayor=sueldos[f];
pos=f;
}
}
Console.WriteLine("El empleado con
sueldo mayor es "+nombres[pos]);
Console.WriteLine("Tiene un
sueldo:"+mayor);
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector11 pv = new
PruebaVector11();
pv.Cargar();
pv.MayorSueldo();
}
}
}
Definimos los dos vectores paralelos donde almacenaremos los nombres y los
sueldos de los operarios:
private string[] nombres;
private float[] sueldos;
linea = Console.ReadLine();
sueldos[f]=float.Parse(linea);
}
Para obtener el mayor sueldo y el nombre del operario realizar los siguientes pasos:
Inicializamos una variable mayor con la primer componente del vector sueldos:
mayor=sueldos[0];
Inicializamos una variable pos con el valor 0, ya que decimos primeramente que el
mayor es la primer componente del vector:
pos=0;
mayor
es
Problemas propuestos
1. Cargar un vector de n elementos. imprimir el menor y un mensaje si se repite
dentro del vector.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector12
{
class PruebaVector12
{
private int[] vec;
private int menor;
public void Cargar()
{
Console.Write("Cuantos elementos desea cargar:");
string linea;
linea = Console.ReadLine();
int n=int.Parse(linea);
vec=new int[n];
for(int f=0;f < vec.Length;f++)
{
Console.Write("Ingrese componente:");
linea = Console.ReadLine();
vec[f]=int.Parse(linea);
}
}
public void MenorElemento()
{
menor=vec[0];
for(int f=1;f < vec.Length;f++)
{
if (vec[f] < menor)
{
menor=vec[f];
}
}
Console.WriteLine("El elemento menor es:"+menor);
}
public void RepiteMenor()
{
int cant=0;
for(int f=0;f < vec.Length;f++)
{
if (vec[f]==menor)
{
cant++;
}
}
if (cant > 1)
{
Console.WriteLine("Se repite el menor en el
vector.");
}
else
{
Console.WriteLine("No se repite el menor en el
vector.");
}
Console.ReadLine();
}
static void Main(string[] args)
{
PruebaVector12 pv = new PruebaVector12();
pv.Cargar();
pv.MenorElemento();
pv.RepiteMenor();
}
}
}
Problema 1:
Se debe crear un vector donde almacenar 5 sueldos. Ordenar el vector sueldos de
menor a mayor.
Esta primera aproximacin tiene por objetivo analizar los intercambios de elementos
dentro del vector.
El algoritmo consiste en comparar si la primera componente es mayor a la segunda, en
caso que la condicin sea verdadera, intercambiamos los contenidos de las
componentes.
Vamos a suponer que se ingresan los siguientes valores por teclado:
1200
750
820
550
490
En este ejemplo: es 1200 mayor a 750? La respuesta es verdadera, por lo tanto
intercambiamos el contenido de la componente 0 con el de la componente 1.
Luego comparamos el contenido de la componente 1 con el de la componente 2: Es
1200
mayor
a
820?
La
respuesta
es
verdadera
entonces
intercambiamos.
Si hay 5 componentes hay que hacer 4 comparaciones, por eso el for se repite 4 veces.
Generalizando: si el vector tiene N componentes hay que hacer N-1 comparaciones.
Cuando
f = 0
f = 1
f = 2
f = 3
750
1200
820
550
750
820
1200
550
750
820
550
1200
750
820
550
490
490
490
490
1200
Podemos ver cmo el valor ms grande del vector desciende a la ltima componente.
Empleamos una variable auxiliar (aux) para el proceso de intercambio:
aux=sueldos[f];
sueldos[f]=sueldos[f+1];
sueldos[f+1]=aux;
Al salir del for en este ejemplo el contenido del vector es el siguiente:
750
820
550
490
1200
Analizando el algoritmo podemos comprobar que el elemento mayor del vector se ubica
ahora
en
el
ltimo
lugar.
Podemos definir otros vectores con distintos valores y comprobar que siempre el
elemento mayor queda al final.
Pero todava con este algoritmo no se ordena un vector. Solamente est ordenado el
ltimo elemento del vector.
Ahora bien, con los 4 elementos que nos quedan podemos hacer el mismo proceso
visto anteriormente, con lo cual quedar ordenado otro elemento del vector. Este
proceso lo repetiremos hasta que quede ordenado por completo el vector.
Como debemos repetir el mismo algoritmo podemos englobar todo el bloque en otra
estructura repetitiva.
f = 2
750
820
550
1200
490
f = 3
750
820
550
490
1200
Cuando k = 1
f = 0
750
820
550
490
1200
f = 1
750
550
820
490
1200
f = 2
750
550
490
820
1200
f = 3
750
550
490
820
1200
f = 0
f = 1
f = 3
Cuando k = 2
= 2
550
750
490
820
1200
550
490
750
820
1200
550
490
750
820
1200
550
490
750
820
1200
Cuando k = 3
f = 0
f = 1
f = 2
f = 3
490
490
490
490
550
550
550
550
750
750
750
750
820
820
820
820
1200
1200
1200
1200
Porque repetimos 4 veces el for externo?
Como sabemos cada vez que se repite en forma completa el for interno queda
ordenada una componente del vector. A primera vista diramos que deberamos repetir
el for externo la cantidad de componentes del vector, en este ejemplo el vector sueldos
tiene 5 componentes.
Si observamos, cuando quedan dos elementos por ordenar, al ordenar uno de ellos
queda el otro automticamente ordenado (podemos imaginar que si tenemos un vector
con 2 elementos no se requiere el for externo, porque este debera repetirse una nica
vez)
Una ltima consideracin a este ALGORITMO de ordenamiento es que los elementos
que se van ordenando continuamos comparndolos.
Ejemplo: En la primera ejecucin del for interno el valor 1200 queda ubicado en la
posicin 4 del vector. En la segunda ejecucin comparamos si el 820 es mayor a 1200,
lo
cual
seguramente
ser
falso.
Podemos concluir que la primera vez debemos hacer para este ejemplo 4
comparaciones, en la segunda ejecucin del for interno debemos hacer 3
comparaciones y en general debemos ir reduciendo en uno la cantidad de
comparaciones.
Si bien el algoritmo planteado funciona, un algoritmo ms eficiente, que se deriva del
anterior es el plantear un for interno con la siguiente estructura: (f=0 ; f<4-k; f++)
Es decir restarle el valor del contador del for externo.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector13
{
class PruebaVector13
{
private int[] sueldos;
public void Cargar()
{
sueldos=new int[5];
for(int f=0;f < sueldos.Length;f++)
{
Console.Write("Ingrese el sueldo:");
string linea = Console.ReadLine();
sueldos[f]=int.Parse(linea);
}
}
public void Ordenar()
{
for (int k = 0; k < 4; k++)
{
for (int f = 0; f < 4 - k; f++)
{
if (sueldos[f] > sueldos[f + 1])
{
int aux;
aux = sueldos[f];
sueldos[f] = sueldos[f + 1];
sueldos[f + 1] = aux;
}
}
}
}
public void Imprimir()
{
Console.WriteLine("Sueldos ordenados de
menor a mayor.");
for(int f=0;f < sueldos.Length;f++)
{
Console.WriteLine(sueldos[f]);
}
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector13 pv = new PruebaVector13();
pv.Cargar();
pv.Ordenar();
pv.Imprimir();
}
}
}
Tambin podemos ordenar vectores cuyas componentes sean de tipo String. Para esto
no podemos utilizar el operador > sino debemos utilizar un mtodo de la clase String:
string cad1="juan";
string cad2="analia";
if (cad1.CompareTo(cad2)>0)
{
Console.Write(cad1 + " es mayor alfabticamente que " +
cad2);
}
El mtodo CompareTo retorna un valor mayor a cero si cad1 es mayor alfabticamente.
En este ejemplo cad1 tiene un valor alfabticamente mayor a cad2, luego el
CompareTo retorna un valor mayor a cero.
Si los dos string son exactamente iguales el mtodo CompareTo retorna un cero, y
finalmente si cad1 es menor alfabticamente retorna un valor menor a cero.
Problema 2:
Definir un vector donde almacenar los nombres de 5 paises. Confeccionar el algoritmo
de ordenamiento alfabtico.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector14
{
class PruebaVector14
{
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector14 pv = new PruebaVector14();
pv.Cargar();
pv.Ordenar();
pv.Imprimir();
}
}
}
Definimos un vector de tipo string:
private string[] paises;
Lo creamos indicando que almacenar cinco elementos:
paises=new string[5];
Procedemos a cargar el vector:
for(int f=0;f < paises.Length;f++)
{
Console.Write("Ingrese el nombre del pais:");
paises[f]=Console.ReadLine();
}
Para el ordenamiento utilizamos el mtodo CompareTo para verificar si tenemos que
intercambiar las componentes:
if (paises[f].CompareTo(paises[f + 1])>0)
En el caso que si tenemos que intercambiarla utilizamos un auxilir de tipo string:
string aux;
aux = paises[f];
paises[f] = paises[f + 1];
paises[f + 1] = aux;
Problemas propuestos
1. Cargar un vector de n elementos de tipo entero. Ordenar posteriormente el vector.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector15
{
class PruebaVector15
{
private int[] vec;
public void Cargar()
{
Console.Write("Cuantos elementos tendr el
vector:");
string linea;
linea = Console.ReadLine();
int cant;
cant=int.Parse(linea);
vec=new int[cant];
for(int f=0;f < vec.Length;f++)
{
Console.Write("Ingrese elemento:");
linea = Console.ReadLine();
vec[f]=int.Parse(linea);
}
}
public void Ordenar()
{
for (int k = 0; k < vec.Length; k++)
{
for (int f = 0; f < vec.Length - 1 - k; f++)
{
if (vec[f] > vec[f + 1])
{
int aux;
aux = vec[f];
vec[f] = vec[f + 1];
vec[f + 1] = aux;
}
}
}
}
public void Imprimir()
{
Console.WriteLine("Vector ordenados de menor a
mayor.");
for(int f=0;f < vec.Length;f++)
{
Console.WriteLine(vec[f]);
}
Console.ReadKey();
}
static void Main(string[] args)
{
PruebaVector15 pv = new PruebaVector15();
pv.Cargar();
pv.Ordenar();
pv.Imprimir();
}
}
}
Problema 1:
Confeccionar un programa que permita cargar los nombres de 5 alumnos y sus notas
respectivas. Luego ordenar las notas de mayor a menor. Imprimir las notas y los
nombres de los alumnos.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector16
{
class PruebaVector16
{
private string[] nombres;
private int[] notas;
public void Cargar()
{
nombres=new string[5];
notas=new int[5];
Console.WriteLine("Carga de nombres y
notas");
Como vemos utilizamos dos auxiliares distintos porque los elementos de los dos
vectores son de distinto tipo (int y string)
Si deseamos ordenar alfabticamente la condicin depender del vector nombres.
Problemas propuestos
1. Cargar en un vector los nombres de 5 paises y en otro vector paralelo la cantidad de
habitantes del mismo. Ordenar alfabticamente e imprimir los resultados. Por ltimo
ordenar con respecto a la cantidad de habitantes (de mayor a menor) e imprimir
nuevamente.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaVector17
{
class PruebaVector17
{
private string[] paises;
private int[] habitantes;
public void Cargar()
{
paises=new string[5];
habitantes=new int[5];
Console.WriteLine("Carga de paises y habitantes");
for(int f=0;f < paises.Length;f++)
{
Console.Write("Ingese el nombre del pais:");
paises[f]=Console.ReadLine();
Console.Write("Ingrese la cantidad de
habitantes:");
string linea;
linea = Console.ReadLine();
habitantes[f]=int.Parse(linea);
}
}
public void OrdenarPorNombres()
{
for (int k = 0; k < paises.Length; k++)
{
for (int f = 0; f < paises.Length - 1 - k; f++)
{
if (paises[f].CompareTo(paises[f + 1]) > 0)
{
string auxpais;
auxpais = paises[f];
paises[f] = paises[f + 1];
paises[f + 1] = auxpais;
int auxhabitante;
auxhabitante = habitantes[f];
habitantes[f] = habitantes[f + 1];
habitantes[f + 1] = auxhabitante;
}
}
}
}
public void OrdenarPorHabitantes()
{
for (int k = 0; k < paises.Length; k++)
{
for (int f = 0; f < paises.Length - 1 - k; f++)
{
if (habitantes[f] < habitantes[f + 1])
{
string auxpais;
auxpais = paises[f];
paises[f] = paises[f + 1];
paises[f + 1] = auxpais;
int auxhabitante;
auxhabitante = habitantes[f];
habitantes[f] = habitantes[f + 1];
habitantes[f + 1] = auxhabitante;
}
}
}
}
public void Imprimir()
{
for(int f=0;f < paises.Length;f++)
{
Console.WriteLine(paises[f] + " - " +
habitantes[f]);
}
}
static void Main(string[] args)
{
PruebaVector17 pv = new PruebaVector17();
pv.Cargar();
pv.OrdenarPorNombres();
Console.WriteLine("Ordenados alfabticamente");
pv.Imprimir();
pv.OrdenarPorHabitantes();
Console.WriteLine("Ordenados por cantidad de
habitnates");
pv.Imprimir();
Console.ReadKey();
}
}
}
Hemos graficado una matriz de 3 filas y 5 columnas. Para hacer referencia a cada
elemento debemos indicar primero la fila y luego la columna, por ejemplo en la
componente 1,4 se almacena el valor 97.
En este ejemplo almacenamos valores enteros. Todos los elementos de la matriz
deben ser del mismo tipo (int, float, string etc.)
Las filas y columnas comienzan a numerarse a partir de cero, similar a los vectores.
Problema 1:
Crear una matriz de 3 filas por 5 columnas con elementos de tipo int, cargar sus
componentes y luego imprimirlas.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz1
{
class Matriz1
{
private int[,] mat;
public void Cargar()
{
mat=new int[3,5];
for(int f = 0;f < 3;f++)
{
for(int c = 0;c < 5;c++)
{
Console.Write("Ingrese
componente:");
string linea;
linea = Console.ReadLine();
mat[f,c]=int.Parse(linea);
}
}
}
public void Imprimir()
{
for(int f = 0;f < 3;f++)
{
for(int c = 0;c < 5;c++)
{
Console.Write(mat[f,c]+" ");
}
Console.WriteLine();
}
Console.ReadKey();
}
static void Main(string[] args)
{
Matriz1 ma = new Matriz1();
ma.Cargar();
ma.Imprimir();
}
}
}
Para definir una matriz debemos disponer una coma dentro de los corchetes:
private int[,] mat;
Para imprimir la matriz de forma similar utilizamos dos for para acceder a cada
elemento de la matriz:
for(int f = 0;f < 3;f++)
{
for(int c = 0;c < 5;c++)
{
Console.Write(mat[f,c]+" ");
}
Console.WriteLine();
}
Cada vez que se ejecuta todas las vueltas del for interno tenemos en pantalla una
fila completa de la matriz, por eso pasamos a ejecutar un salto de lnea (con esto
logramos que en pantalla los datos aparezcan en forma matricial):
Console.WriteLine();
Problema 2:
Crear y cargar una matriz de 4 filas por 4 columnas. Imprimir la diagonal principal.
x
-
x
-
x
-
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz2
{
class Matriz2
{
private int[,] mat;
public void Cargar()
{
mat=new int[4,4];
for(int f = 0; f < 4; f++)
{
for(int c = 0; c<4; c++)
{
Console.Write("Ingrese
componente:");
string linea;
linea = Console.ReadLine();
mat[f, c] = int.Parse(linea);
}
}
}
public void ImprimirDiagonalPrincipal()
{
for(int k = 0; k < 4; k++)
{
Console.Write(mat[k,k]+" ");
}
Console.ReadKey();
}
static void Main(string[] args)
{
Matriz2 ma = new Matriz2();
ma.Cargar();
ma.ImprimirDiagonalPrincipal();
}
}
}
La definicin, creacin y carga de la matriz no varan con el ejemplo anterior.
Para imprimir la diagonal principal de la matriz lo ms conveniente es utilizar un for
que se repita 4 veces y disponer como subndice dicho contador (los elementos de
la diagonal principal coinciden los valores de la fila y columna):
for(int k = 0; k < 4; k++)
{
Console.Write(mat[k,k]+" ");
}
Problema 3:
Crear y cargar una matriz de 3 filas por 4 columnas. Imprimir la primer fila. Imprimir
la ltima fila e imprimir la primer columna.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz3
{
class Matriz3
{
private int[,] mat;
public void Cargar()
{
mat=new int[3,4];
for(int f = 0; f < 3; f++)
{
for(int c = 0; c < 4; c++)
{
Console.Write("Ingrese
componente:");
string linea;
linea = Console.ReadLine();
mat[f,c]=int.Parse(linea);
}
}
}
public void PrimerFila()
{
Console.WriteLine("Primer fila de la
matriz:");
for(int c = 0; c < 4; c++)
{
Console.WriteLine(mat[0,c]);
}
}
public void UltimaFila()
{
Console.WriteLine("Ultima fila de la
matriz:");
for(int c = 0; c < 4; c++)
{
Console.WriteLine(mat[2,c]);
}
}
public void PrimerColumna()
{
Console.WriteLine("Primer columna:");
for(int f = 0; f < 3; f++)
{
Console.WriteLine(mat[f,0]);
}
}
static void Main(string[] args)
{
Matriz3 ma = new Matriz3();
ma.Cargar();
ma.PrimerFila();
ma.UltimaFila();
ma.PrimerColumna();
Console.ReadKey();
}
}
}
Creamos una matriz de 3 filas y 4 columnas:
mat=new int[3,4];
Para imprimir la ltima fila el algoritmo es similar, disponemos un for que se repita 4
veces y en el subndice de la fila disponemos el valor 2 (ya que la matriz tiene 3
filas):
Console.WriteLine("Ultima fila de la matriz:");
for(int c = 0; c < 4; c++)
{
Console.WriteLine(mat[2,c]);
}
Para imprimir la primer columna el for debe repetirse 3 veces ya que la matriz tiene
3 filas. Dejamos constante el subndice de la columna con el valor cero:
Console.WriteLine("Primer columna:");
for(int f = 0; f < 3; f++)
{
Console.WriteLine(mat[f,0]);
}
Problemas propuestos
1. Crear una matriz de 2 filas y 5 columnas. Realizar la carga de componentes
por columna (es decir primero ingresar toda la primer columna, luego la
segunda
columna
y
as
sucesivamente)
Imprimir luego la matriz.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz4
{
class Matriz4
{
private int[,] mat;
public void Cargar()
{
mat=new int[2,5];
Console.WriteLine("Carga de la matriz por
columna:");
for(int c = 0; c < 5; c++)
{
for(int f = 0; f < 2; f++)
{
Console.Write("Ingrese componente " + " de
la fila " + f + " y la columna "+ c + " :");
string linea;
linea = Console.ReadLine();
mat[f,c]=int.Parse(linea);
}
}
}
Creacin:
mat=new int[3,4];
Problema 1:
Crear una matriz de n * m filas (cargar n y m por teclado) Imprimir la matriz
completa y la ltima fila.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz5
{
class Matriz5
{
private int[,] mat;
public void Cargar()
{
Console.Write("Cuantas fila tiene la
matriz:");
string linea;
linea=Console.ReadLine();
int filas=int.Parse(linea);
Console.Write("Cuantas columnas tiene
la matriz:");
linea=Console.ReadLine();
int columnas=int.Parse(linea);
mat=new int[filas,columnas];
for(int f = 0; f < mat.GetLength(0);
f++)
{
for (int c = 0; c <
mat.GetLength(1); c++)
{
Console.Write("Ingrese
componente:");
linea = Console.ReadLine();
mat[f,c] = int.Parse(linea);
}
}
}
Para imprimir la ltima fila debemos disponer un valor fijo en el subndice de la fila
(en este caso no podemos disponer un nmero fijo sino preguntarle a la misma
matriz la cantidad de filas y restarle uno ya que las filas comienzan a numerarse a
partir de cero: mat[mat.GetLength(0)-1,c]
Tambin la condicin del for debemos preguntar a la matriz la cantidad de columnas
mat.GetLength(1):
Console.WriteLine("Ultima fila");
for(int c = 0; c < mat.GetLength(1); c++)
{
Console.Write(mat[mat.GetLength(0)-1,c]+" ");
}
Problema 2:
Crear una matriz de n * m filas (cargar n y m por teclado) Imprimir el mayor
elemento y la fila y columna donde se almacena.
Programa:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Matriz6
{
class Matriz6
{
private int[,] mat;
public void Cargar()
{
Console.Write("Cuantas fila tiene la
matriz:");
string linea;
linea=Console.ReadLine();
int filas=int.Parse(linea);
Console.Write("Cuantas columnas tiene
la matriz:");
linea=Console.ReadLine();
int columnas=int.Parse(linea);
mat=new int[filas,columnas];
for(int f = 0; f < mat.GetLength(0);
f++)
{
for(int c = 0; c <=""
mat.getlength(0);="" f++)="" c="0;"
mat.getlength(1);="" if="" (mat[f,c]=""> mayor)
{
mayor=mat[f,c];
filamay=f;
columnamay=c;
}
}
}
Console.WriteLine("El elemento mayor
es:"+mayor);
Console.WriteLine("Se encuentra en la
fila:"+filamay+ " y en la columna: "+columnamay);
Console.ReadLine();
}
static void Main(string[] args)
{
Matriz6 ma = new Matriz6();
ma.Cargar();
ma.ImprimirMayor();
}
}
}
Para obtener el mayor elemento de la matriz y la fila y columna donde se ubica
debemos inicializar una variable mayor con el elemento de la fila cero y columna
cero (esto lo hacemos suponiendo que en dicha posicin se almacena el mayor):
int mayor=mat[0,0];
int filamay=0;
int columnamay=0;
Luego mediante dos for recorremos todos los elementos de la matriz y cada vez
que encontramos un elemento mayor al actual procedemos a actualizar la variable
mayor y la posicin donde se almacena:
for(int f = 0; f < mat.GetLength(0); f++)
{
for(int c = 0; c < mat.GetLength(1); c++)
{
if (mat[f,c] > mayor)
{
mayor=mat[f,c];
filamay=f;
columnamay=c;
}
}
}
Problemas propuestos
1. Crear una matriz de n * m filas (cargar n y m por teclado) Intercambiar la
primer fila con la segundo. Imprimir luego la matriz.
2. Crear una matriz de n * m filas (cargar n y m por teclado) Imprimir los cuatro
valores que se encuentran en los vrtices de la misma (mat[0][0] etc.)
SOLUCION
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Matriz7
{
class Matriz7
{
private int[,] mat;
public void Cargar()
{
Console.Write("Cuantas fila tiene la matriz:");
string linea;
linea=Console.ReadLine();
int filas=int.Parse(linea);
Console.Write("Cuantas columnas tiene la matriz:");
linea=Console.ReadLine();
int columnas=int.Parse(linea);
mat=new int[filas,columnas];
for(int f = 0; f < mat.GetLength(0); f++)
{
for(int c = 0;c < mat.GetLength(1); c++)
{
Console.Write("Ingrese componente:");
linea = Console.ReadLine();
mat[f,c]=int.Parse(linea);
}
}
}
public void Intercambiar()
{
for (int c = 0; c < mat.GetLength(0); c++)
{
int aux = mat[0,c];
mat[0,c] = mat[1,c];
mat[1,c] = aux;
}
}
public void Imprimir()
{
for(int f = 0; f < mat.GetLength(0); f++)
{
for(int c = 0; c < mat.GetLength(1); c++)
{
Console.Write(mat[f,c]+" ");
}
Console.WriteLine();
}
Console.ReadKey();
}
static void Main(string[] args)
{
Matriz7 ma = new Matriz7();
ma.Cargar();
ma.Intercambiar();
ma.Imprimir();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz8
{
class Matriz8
{
private int[,] mat;
public void Cargar()
{
Console.Write("Cuantas fila tiene la matriz:");
string linea;
linea=Console.ReadLine();
int filas=int.Parse(linea);
Console.Write("Cuantas columnas tiene la matriz:");
linea=Console.ReadLine();
int columnas=int.Parse(linea);
mat=new int[filas,columnas];
for(int f = 0; f < mat.GetLength(0); f++)
{
for(int c = 0; c < mat.GetLength(1); c++)
{
Console.Write("Ingrese componente:");
linea = Console.ReadLine();
mat[f,c]=int.Parse(linea);
}
}
}
public void ImprimirVertices()
{
Console.WriteLine("Vrtice superior izquierdo:");
Console.WriteLine(mat[0,0]);
Console.WriteLine("Vrtice superior derecho:");
Console.WriteLine(mat[0,mat.GetLength(1)-1]);
Console.WriteLine("Vrtice inferior izquierdo:");
Console.WriteLine(mat[mat.GetLength(0)-1,0]);
Console.WriteLine("Vrtice inferior derecho:");
Console.WriteLine(mat[mat.GetLength(0)1,mat.GetLength(1)-1]);
Console.ReadKey();
}
static void Main(string[] args)
{
Matriz8 ma = new Matriz8();
ma.Cargar();
ma.ImprimirVertices();
}
}
}
Problema 1:
Se
tiene
la
siguiente
informacin:
Nombres
de
4
empleados.
Ingresos en concepto de sueldo, cobrado por cada empleado, en los ltimos 3
meses.
Confeccionar el programa para:
a) Realizar la carga de la informacin mencionada.
b) Generar un vector que contenga el ingreso acumulado en sueldos en los ltimos
3 meses para cada empleado.
c) Mostrar por pantalla el total pagado en sueldos a todos los empleados en los
ltimos 3 meses
d) Obtener el nombre del empleado que tuvo el mayor ingreso acumulado
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz9
{
class Matriz9
{
private string[] empleados;
private int[,] sueldos;
private int[] sueldostot;
public void Cargar()
{
empleados=new String[4];
sueldos=new int[4,3];
for(int f = 0; f < empleados.Length;
f++)
{
Console.Write("Ingrese el nombre
del empleado:");
empleados[f]=Console.ReadLine();
for(int c = 0; c <
sueldos.GetLength(1); c++)
{
Console.Write("Ingrese
sueldo:");
string linea;
linea = Console.ReadLine();
sueldos[f,c]=int.Parse(linea);
}
}
}
public void CalcularSumaSueldos()
{
sueldostot = new int[4];
for (int f = 0; f <
sueldos.GetLength(0); f++)
{
int suma = 0;
for (int c = 0; c <
sueldos.GetLength(1); c++)
{
suma = suma + sueldos[f,c];
}
sueldostot[f] = suma;
}
}
public void ImprimirTotalPagado()
{
Console.WriteLine("Total de sueldos
pagados por empleado.");
for(int f = 0; f < sueldostot.Length;
f++)
{
Console.WriteLine(empleados[f]+" "+sueldostot[f]);
}
}
public void EmpleadoMayorSueldo()
{
int may=sueldostot[0];
string nom=empleados[0];
for(int f = 0; f < sueldostot.Length;
f++)
{
if (sueldostot[f] > may)
{
may=sueldostot[f];
nom=empleados[f];
}
}
Console.WriteLine("El empleado con
mayor sueldo es "+ nom + " que tiene un sueldo de
"+may);
}
static void Main(string[] args)
{
Matriz9 ma = new Matriz9();
ma.Cargar();
ma.CalcularSumaSueldos();
ma.ImprimirTotalPagado();
ma.EmpleadoMayorSueldo();
Console.ReadKey();
}
}
}
Para resolver este problema lo primero que hacemos es definir una matriz donde se
almacenarn los sueldos mensuales de cada empleado, un vector de tipo string
donde almacenaremos los nombre de cada empleado y finalmente definimos un
vector paralelo a la matriz donde almacenaremos la suma de cada fila de la matriz:
private string[] empleados;
private int[,] sueldos;
private int[] sueldostot;
El mtodo sumar sueldos crea el vector donde se almacenar la suma de cada fila
de la matriz. Mediante dos for recorremos toda la matriz y sumamos cada fila:
sueldostot = new int[4];
for (int f = 0; f < sueldos.GetLength(0); f++)
{
int suma = 0;
for (int c = 0; c < sueldos.GetLength(1); c++)
{
suma = suma + sueldos[f,c];
}
sueldostot[f] = suma;
}
El mtodo ImprimirTotalPagado tiene por objetivo mostrar los dos vectores (el de
nombre de los empleados y el que almacena la suma de cada fila de la matriz):
Console.WriteLine("Total de sueldos pagados por empleado.");
for(int f = 0; f < sueldostot.Length; f++)
{
Console.WriteLine(empleados[f]+" - "+sueldostot[f]);
}
Por ltimo para obtener el nombre del empleado con mayor sueldo acumulado
debemos inicializar dos variables auxiliares con el primer elemento del vector de
empleados y en otra auxiliar guardamos la primer componente del vector
sueldostot:
int may=sueldostot[0];
string nom=empleados[0];
for(int f = 0; f < sueldostot.Length; f++)
{
if (sueldostot[f] > may)
{
may=sueldostot[f];
nom=empleados[f];
}
}
Console.WriteLine("El empleado con mayor sueldo es "+ nom + " que
tiene un sueldo de "+may);
Problemas propuestos
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Matriz10
{
class Matriz10
{
private string[] paises;
private int[,] tempmen;
private int[] temptri;
public void Cargar()
{
paises=new String[4];
tempmen=new int[4,3];
for(int f = 0; f < paises.Length; f++)
{
Console.Write("Ingrese el nombre del pas:");
paises[f]=Console.ReadLine();
for(int c = 0; c < tempmen.GetLength(1); c++)
{
Console.Write("Ingrese temperatura
mensual:");
string linea = Console.ReadLine();
tempmen[f,c]=int.Parse(linea);
}
}
}
public void ImprimirTempMensuales()
{
for(int f = 0; f < paises.Length; f++)
{
Console.Write("Pais:" + paises[f]+":");
for(int c = 0; c < tempmen.GetLength(1); c++)
{
Console.Write(tempmen[f,c]+" ");
}
Console.WriteLine();
}
}
public void CalcularTemperaturaTri()
{
temptri = new int[4];
for (int f = 0; f < tempmen.GetLength(0); f++)
{
int suma = 0;
for (int c = 0; c < tempmen.GetLength(1); c++)
{
suma = suma + tempmen[f,c];
}
temptri[f] = suma / 3;
}
}
public void ImprimirTempTrimestrales()
{
Console.WriteLine("Temperaturas trimestrales.");
for(int f = 0; f < paises.Length; f++)
{
Console.WriteLine(paises[f]+" "+temptri[f]);
}
}
public void PaisMayorTemperaturaTri()
{
int may=temptri[0];
string nom=paises[0];
for(int f = 0; f < paises.Length; f++)
{
if (temptri[f] > may)
{
may=temptri[f];
nom=paises[f];
}
}
Console.WriteLine("Pais con temperatura trimestral
mayor es "+ nom + " que tiene una temperatura de "+may);
}
static void Main(string[] args)
{
Matriz10 ma = new Matriz10();
ma.Cargar();
ma.ImprimirTempMensuales();
ma.CalcularTemperaturaTri();
ma.ImprimirTempTrimestrales();
ma.PaisMayorTemperaturaTri();
Console.ReadKey();
}
}
}
Como podemos ver la fila cero tiene reservado dos espacios, la fila uno reserva
cuatro espacios y la ltima fila reserva espacio para tres componentes.
La sintaxis para declarar una matriz irregular es:
int [][] mat;
Primero creamos la cantidad de filas dejando vaco el espacio que indica la cantidad
de columnas:
mat=new int[3][];
Luego la forma para acceder a sus componentes debe ser utilizando corchetes
abiertos y cerrados para cada ndice:
mat[0][0]=120;
Dar un error si queremos cargar la tercer componente de la fila cero (esto debido a
que no existe):
mat[0][2]=230;
Problema 1:
Confeccionaremos un programa que permita crear una matriz irregular y luego
imprimir la matriz en forma completa.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace MatrizIrregular1
{
class MatrizIrregular1
{
private int[][] mat;
public void Cargar()
{
Console.Write("Cuantas fila tiene la
matriz:");
string linea=Console.ReadLine();
int filas=int.Parse(linea);
mat=new int[filas][];
for(int f = 0; f < mat.Length; f++)
{
Console.Write("Cuantas elementos
tiene la fila " + f + ":");
linea = Console.ReadLine();
int elementos=int.Parse(linea);
mat[f]=new int[elementos];
for(int c = 0; c < mat[f].Length;
c++)
{
Console.Write("Ingrese
componente:");
linea=Console.ReadLine();
mat[f][c]=int.Parse(linea);
}
}
}
public void Imprimir()
{
for(int f = 0; f < mat.Length; f++)
{
for(int c = 0; c < mat[f].Length;
c++)
{
Console.Write(mat[f][c]+" ");
}
Console.WriteLine();
}
Console.ReadLine();
}
static void Main(string[] args)
{
MatrizIrregular1 ma = new
MatrizIrregular1();
ma.Cargar();
ma.Imprimir();
}
}
}
Primero creamos la cantidad de filas que tendr la matriz (en los corchetes para las
columnas no disponemos valor):
Console.Write("Cuantas fila tiene la matriz:");
string linea=Console.ReadLine();
int filas=int.Parse(linea);
mat=new int[filas][];
Dentro del primer for pedimos que ingrese la cantidad de elementos que tendr
cada fila y utilizamos el operador new nuevamente, pero en este caso se estn
creando cada fila de la matriz (C# trata a cada fila como un vector):
Console.Write("Cuantas elementos tiene la fila " + f + ":");
linea = Console.ReadLine();
int elementos=int.Parse(linea);
mat[f]=new int[elementos];
Dentro del for interno hacemos la carga de las componentes propiamente dicho de
la matriz (podemos ir cargando cada fila a medida que las vamos creando):
for(int c=0;c < mat[f].Length;c++)
{
Console.Write("Ingrese componente:");
linea=Console.ReadLine();
mat[f][c]=int.Parse(linea);
}
Problemas propuestos
1. Confeccionar una clase para administrar una matriz irregular de 5 filas y 1
columna la primer fila, 2 columnas la segunda fila y as sucesivamente hasta
5 columnas la ltima fila (crearla sin la intervencin del operador)
Realizar la carga por teclado e imprimir posteriormente.
2. Confeccionar una clase para administrar los das que han faltado los 3
empleados
de
una
empresa.
Definir un vector de 3 elementos de tipo string para cargar los nombres y una
matriz irregular para cargar los das que han faltado cada empleado (cargar
el
nmero
de
da
que
falt)
Cada fila de la matriz representan los das de cada empleado.
Mostrar
los
empleados
con
la
cantidad
de
inasistencias.
Cul empleado falt menos das.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace MatrizIrregular2
{
class MatrizIrregular2
{
private int[][] mat;
public void Cargar()
{
mat=new int[5][];
for(int f = 0; f < mat.Length; f++)
{
mat[f]=new int[f+1];
for(int c = 0; c < mat[f].Length; c++)
{
Console.Write("Ingrese componente:");
string linea = Console.ReadLine();
mat[f][c]=int.Parse(linea);
}
}
}
public void Imprimir()
{
for(int f = 0; f < mat.Length; f++)
{
for(int c = 0; c < mat[f].Length; c++)
{
Console.Write(mat[f][c]+" ");
}
Console.WriteLine();
}
Console.ReadKey();
}
static void Main(string[] args)
{
MatrizIrregular2 ma = new MatrizIrregular2();
ma.Cargar();
ma.Imprimir();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace MatrizIrregular3
{
class MatrizIrregular3
{
private string[] nombres;
private int[][] dias;
public void Cargar()
{
nombres=new string[3];
dias=new int[3][];
for(int f = 0; f < nombres.Length; f++)
{
Console.Write("Ingrese el nombre del
empleado:");
nombres[f]=Console.ReadLine();
Console.Write("Cuantas das falt el
empleado:");
string linea = Console.ReadLine();
int faltas=int.Parse(linea);
dias[f]=new int[faltas];
for(int c = 0; c < dias[f].Length; c++)
{
Console.Write("Ingrese nro de da:");
linea = Console.ReadLine();
dias[f][c]=int.Parse(linea);
}
}
}
public void Inasistencias()
{
for(int f = 0; f < nombres.Length; f++)
{
Console.WriteLine(nombres[f] + " falt " +
dias[f].Length + " das");
}
}
public void EmpleadoMensosFaltas()
{
int faltas=dias[0].Length;
string nom=nombres[0];
for(int f = 1; f < dias.Length; f++)
{
if (dias[f].Length < faltas)
{
faltas=dias[f].Length;
nom=nombres[f];
}
}
Console.WriteLine("El empleado que falt menos es
"+nom+" con "+faltas+" faltas.");
Console.ReadKey();
}
static void Main(string[] args)
{
MatrizIrregular3 ma = new MatrizIrregular3();
ma.Cargar();
ma.Inasistencias();
ma.EmpleadoMensosFaltas();
}
}
}
Problema 1:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaConstructor1
{
class Operarios
{
private int[] sueldos;
public Operarios()
{
sueldos=new int[5];
for(int f = 0; f < sueldos.Length; f++)
{
Console.Write("Ingrese el
sueldo:");
string linea = Console.ReadLine();
sueldos[f]=int.Parse(linea);
}
}
public void Imprimir()
{
for(int f = 0; f < sueldos.Length; f++)
{
Console.WriteLine(sueldos[f]);
}
Console.ReadKey();
}
static void Main(string[] args)
{
Problema 2:
Plantear una clase llamada Alumno y definir como atributos su nombre y su edad.
En el constructor realizar la carga de datos. Definir otros dos mtodos para imprimir
los datos ingresados y un mensaje si es mayor o no de edad (edad >=18)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaConstructor2
{
class Alumno
{
private string nombre;
}
}
}
Declaramos la clase Persona, sus dos atributos y definimos el constructor con el
mismo nombre de la clase:
class Alumno
{
private string nombre;
private int edad;
public Alumno()
{
Console.Write("Ingrese nombre:");
nombre = Console.ReadLine();
Console.Write("Ingrese edad:");
string linea = Console.ReadLine();
edad=int.Parse(linea);
}
Los otros dos mtodos deben llamarse por su nombre y en el orden que
necesitemos:
alumno1.Imprimir();
alumno1.EsMayorEdad();
Problemas propuestos
1. Confeccionar una clase que represente un empleado. Definir como atributos
su nombre y su sueldo. En el constructor cargar los atributos y luego en otro
mtodo imprimir sus datos y por ltimo uno que imprima un mensaje si debe
pagar impuestos (si el sueldo supera a 3000)
2. Implementar la clase operaciones. Se deben cargar dos valores enteros en el
constructor, calcular su suma, resta, multiplicacin y divisin, cada una en un
mtodo, imprimir dichos resultados.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaConstructor3
{
class EmpleadoFabrica
{
string nombre;
float sueldo;
public EmpleadoFabrica()
{
Console.Write("Ingrese el nombre del empleado:");
nombre = Console.ReadLine();
Console.Write("Ingrese su sueldo:");
string linea = Console.ReadLine();
sueldo = float.Parse(linea);
}
public void PagaImpuestos()
{
if (sueldo > 3000)
{
Console.Write("Debe abonar impuestos");
}
else
{
Console.Write("No paga impuestos");
}
Console.ReadKey();
}
static void Main(string[] args)
{
EmpleadoFabrica empleado1;
empleado1 = new EmpleadoFabrica();
empleado1.PagaImpuestos();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PruebaConstructor4
{
class OperacionesCalculo
{
opera.Dividir();
Console.ReadKey();
}
}
}
Problema 1:
Un banco tiene 3 clientes que pueden hacer depsitos y extracciones. Tambin el
banco requiere que al final del da calcule la cantidad de dinero que hay depositada.
Lo primero que hacemos es identificar las clases:
Podemos identificar la clase Cliente y la clase Banco.
Luego debemos definir los atributos y los mtodos de cada clase:
Cliente
atributos
nombre
monto
mtodos
constructor
Depositar
Extraer
RetornarMonto
Banco
atributos
3 Cliente (3 objetos de la clase Cliente)
mtodos
constructor
Operar
DepositosTotales
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Colaboracion1
{
class Cliente
{
private string nombre;
private int monto;
public Cliente(string nom)
{
nombre = nom;
monto = 0;
}
public void Depositar(int m)
{
monto = monto + m;
}
public void Extraer(int m)
{
monto = monto - m;
}
public int RetornarMonto()
{
return monto;
}
public void Imprimir()
{
Console.WriteLine(nombre+" tiene
depositado la suma de "+monto);
}
}
class Banco
{
}
}
Analicemos la implementacin del problema.
Los atributos de una clase normalmente son privados para que no se tenga acceso
directamente desde otra clase, los atributos son modificados por los mtodos de la
misma clase:
private string nombre;
private int monto;
Los mtodos Depositar y Extraer actualizan el atributo monto con el dinero que llega
como parmetro (para simplificar el problema no hemos validado que cuando se
extrae dinero el atributo monto quede con un valor negativo):
public void Depositar(int m)
{
monto = monto + m;
}
public void Extraer(int m)
{
monto = monto - m;
}
Por ltimo el mtodo imprimir muestra nombre y el monto de dinero del cliente:
public void Imprimir()
{
Console.WriteLine(nombre+" tiene depositado la suma de "+monto);
}
Como podemos observar la clase Cliente no tiene funcin Main. Entonces donde
definimos
objetos
de
la
clase
Cliente?
La respuesta a esta pregunta es que en la clase Banco definimos tres objetos de la
clase Cliente.
Veamos ahora la clase Banco que requiere la colaboracin de la clase Cliente.
Primero definimos tres atributos de tipo Cliente:
class Banco
{
private Cliente cliente1, cliente2, cliente3;
En le constructor creamos los tres objetos (cada vez que creamos un objeto de la
clase Cliente debemos pasar a su constructor el nombre del cliente, recordemos
que su monto de depsito se inicializa con cero):
public Banco()
{
cliente1=new Cliente("Juan");
cliente2=new Cliente("Ana");
cliente3=new Cliente("Pedro");
}
El mtodo operar del banco (llamamos a los mtodos Depositar y Extraer de los
clientes):
public void Operar()
{
cliente1.Depositar(100);
cliente2.Depositar(150);
cliente3.Depositar(200);
cliente3.Extraer(150);
}
Por ltimo en la Main definimos un objeto de la clase Banco (la clase Banco es la
clase principal en nuestro problema):
static void Main(string[] args)
{
Banco banco1 = new Banco();
banco1.Operar();
banco1.DepositosTotales();
Console.ReadKey();
}
Problema 2:
Plantear un programa que permita jugar a los dados. Las reglas de juego son: se
tiran tres dados si los tres salen con el mismo valor mostrar un mensaje que "gano",
sino "perdi".
Lo primero que hacemos es identificar las clases:
Podemos identificar la clase Dado y la clase JuegoDeDados.
Luego los atributos y los mtodos de cada clase:
Dado
atributos
valor
mtodos
constructor
Tirar
Imprimir
RetornarValor
JuegoDeDados
atributos
3 Dado (3 objetos de la clase Dado)
mtodos
constructor
Jugar
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Colaboracion2
{
class Dado
{
private int valor;
private static Random aleatorio;
public Dado()
{
aleatorio = new Random();
}
public void Tirar()
{
valor = aleatorio.Next(1, 7);
}
public void Imprimir()
{
Console.WriteLine("El valor del dado
es:"+valor);
}
public int RetornarValor()
{
return valor;
}
}
class JuegoDeDados
{
private Dado dado1,dado2,dado3;
public JuegoDeDados()
{
dado1=new Dado();
dado2=new Dado();
dado3=new Dado();
}
public void Jugar()
{
dado1.Tirar();
dado1.Imprimir();
dado2.Tirar();
dado2.Imprimir();
dado3.Tirar();
dado3.Imprimir();
if
(dado1.RetornarValor()==dado2.RetornarValor() &&
dado1.RetornarValor()==dado3.RetornarValor())
{
Console.WriteLine("Gan");
}
else
{
Console.WriteLine("Perdi");
}
Console.ReadKey();
}
static void Main(string[] args)
{
JuegoDeDados j = new JuegoDeDados();
j.Jugar();
}
}
}
La clase Dado define el atributo "valor" donde almacenamos un valor aleatorio que
representa
el
nmero
que
sale
al
tirarlo.
Definimos otro atributo de la clase Random. Esta clase nos facilita la generacin de
un nmero aleatorio que nos indicar el valor del dato. Como luego se crearn tres
objetos de la clase dado y nosotros solo requerimos un objeto de la clase Random
luego definimos el atributo de tipo static, con esto todos los objetos de la clase Dado
acceden al mismo objeto de la clase Random:
private int valor;
private static Random aleatorio;
El mtodo Imprimir de la clase Dado muestra por pantalla el valor del dado:
public void Imprimir()
{
Console.WriteLine("El valor del dado es:"+valor);
}
Por ltimo el mtodo que retorna el valor del dado (se utiliza en la otra clase para
ver si los tres dados generaron el mismo valor):
public int RetornarValor()
{
return valor;
}
La clase JuegoDeDatos define tres atributos de la clase Dado (con esto decimos
que la clase Dado colabora con la clase JuegoDeDados):
class JuegoDeDados
{
private Dado dado1,dado2,dado3;
En la Main creamos solo un objeto de la clase principal (en este caso la clase
principal es el JuegoDeDados):
static void Main(string[] args)
{
JuegoDeDados j = new JuegoDeDados();
j.Jugar();
}
Problemas propuestos
1. Plantear
una
clase
Club
y
otra
clase
Socio.
La clase Socio debe tener los siguientes atributos privados: nombre y la
antigedad en el club (en aos). En el constructor pedir la carga del nombre y
su antigedad. La clase Club debe tener como atributos 3 objetos de la clase
Socio. Definir una responsabilidad para imprimir el nombre del socio con
mayor antigedad en el club.
SOLUCION
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Colaboracion3
{
class Socio
{
private string nombre;
private int antiguedad;
public Socio()
{
Console.Write("Ingrese el nombre del socio:");
nombre = Console.ReadLine(); ;
Console.Write("Ingrese la antiguedad:");
string linea = Console.ReadLine();
antiguedad=int.Parse(linea);
}
public void Imprimir()
{
Console.WriteLine(nombre+" tiene una antiguedad de
"+antiguedad);
}
public int RetornarAntiguedad()
{
return antiguedad;
}
}
class Club
{
private Socio socio1, socio2, socio3;
public Club()
{
socio1=new Socio();
socio2=new Socio();
socio3=new Socio();
}
public void MayorAntiguedad()
{
Console.Write("Socio con mayor antiguedad:");
if (socio1.RetornarAntiguedad() >
socio2.RetornarAntiguedad() &&
socio1.RetornarAntiguedad() >
socio3.RetornarAntiguedad())
{
socio1.Imprimir();
}
else
{
if (socio2.RetornarAntiguedad() >
socio3.RetornarAntiguedad())
{
socio2.Imprimir();
}
else
{
socio3.Imprimir();
}
}
}
static void Main(string[] args)
{
Club club1 = new Club();
club1.MayorAntiguedad();
Console.ReadKey();
}
}
}
cliente3.Extraer(150);
Problema 1:
El problema era : Un banco tiene 3 clientes que pueden hacer depsitos y
extracciones. Tambin el banco requiere que al final del da calcule la cantidad de
dinero que hay depositada.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Propiedades1
{
class Cliente
{
private string nombre;
private int monto;
public string Nombre
{
set
{
nombre = value;
}
get
{
return nombre;
}
}
public int Monto
{
set
{
monto = value;
}
get
{
return monto;
}
}
public void Imprimir()
{
Console.WriteLine(Nombre + " tiene
depositado la suma de " + Monto);
}
}
class Banco
{
private Cliente cliente1, cliente2,
cliente3;
public Banco()
{
cliente1 = new Cliente();
cliente1.Nombre = "Juan";
cliente1.Monto = 0;
cliente2 = new Cliente();
cliente2.Nombre = "Ana";
cliente2.Monto = 0;
cliente3 = new Cliente();
cliente3.Nombre = "Pedro";
cliente3.Monto = 0;
}
public void Operar()
{
cliente1.Monto = cliente1.Monto + 100;
cliente2.Monto = cliente2.Monto + 150;
{
set
{
monto = value;
}
get
{
return monto;
}
}
Podemos observar que la sintaxis para acceder a las propiedades donde definimos
objetos es mucho mas intuitiva y sencillas, por ejemplo para saber cuanto dinero
hay en el banco la sintaxis con propiedades es:
int t = cliente1.Monto + cliente2.Monto + cliente3.Monto;
Lo primero que nos viene a la mente es porque no definir los atributos con el
modificador public :
public int monto;
restriccin que el Monto siempre debe ser positivo para que se almacene, luego
debemos codificar la propiedad con la siguiente sintaxis:
public int Monto
{
set
{
if (value >= 0)
{
monto = value;
}
else
{
Console.WriteLine("No
negativo.");
}
}
get
{
return monto;
}
}
se
puede
tener
un
monto
Problema 2:
Plantear un programa que permita jugar a los dados. Las reglas de juego son: se
tiran tres dados si los tres salen con el mismo valor mostrar un mensaje que "gano",
sino "perdi".
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace
{
using
using
using
using
Propiedades2
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Colaboracion2
{
class Dado
{
private int valor;
public int Valor
{
get
{
return valor;
}
private set
{
valor = value;
}
}
private static Random aleatorio;
public Dado()
{
aleatorio = new Random();
}
public void Tirar()
{
Valor = aleatorio.Next(1, 7);
}
public void Imprimir()
{
Console.WriteLine("El valor del
dado es:" + Valor);
}
}
class JuegoDeDados
{
private Dado dado1, dado2, dado3;
public JuegoDeDados()
{
dado1 = new Dado();
dado2 = new Dado();
dado3 = new Dado();
}
public void Jugar()
{
dado1.Tirar();
dado1.Imprimir();
dado2.Tirar();
dado2.Imprimir();
dado3.Tirar();
dado3.Imprimir();
if (dado1.Valor == dado2.Valor &&
dado1.Valor == dado3.Valor)
{
Console.WriteLine("Gan");
}
else
{
Console.WriteLine("Perdi");
}
Console.ReadKey();
}
static void Main(string[] args)
{
JuegoDeDados j = new
JuegoDeDados();
j.Jugar();
}
}
}
}
El atributo valor se lo accede por medio de la propiedad Valor:
private int valor;
public int Valor
{
get
{
return valor;
}
private set
{
valor = value;
}
}
Luego cuando queremos consultar el valor del dado desde el jugo de dados por
medio de la sintaxis siguiente podemos comparar si los tres dados tienen el mismo
nmero:
if (dado1.Valor == dado2.Valor && dado1.Valor == dado3.Valor)
{
Console.WriteLine("Gan");
}
else
{
Console.WriteLine("Perdi");
}
Algo importante es poder restringir la ejecucin del set o get desde fuera de la
clase, por ejemplo en este caso queremos evitar que desde la clase JuegoDeDados
se puede cambiar el valor del dado con la siguiente sintaxis:
dado1.Valor=7;
La lnea anterior provocar un error ya que seccin del set de la propiedad la hemos
definido de tipo private (con esto hacemos que solo los mtodos de la clase puedan
ejecuta el set. La sintaxis para acceder a la propiedad Valor desde la clase es:
public void Tirar()
{
Valor = aleatorio.Next(1, 7);
}
Esto es correcto ya que el mtodo Tirar pertenece a la clase Dado y por lo tanto
puede asignarle un valor a la propiedad Valor (cuando se asigna un valor a una
propiedad se ejecuta el set)
Problemas propuestos
1. Plantear
una
clase
Club
y
otra
clase
Socio.
La clase Socio debe tener los siguientes atributos privados: nombre y la
antigedad en el club (en aos) Definir dos propiedades para poder acceder
al nombre y la antigedad del socio(no permitir cargar un valor negativo en la
antigedad). La clase Club debe tener como atributos 3 objetos de la clase
Socio. Definir una responsabilidad para imprimir el nombre del socio con
mayor antigedad en el club.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Propiedades3
{
class Socio
{
private string nombre;
private int antiguedad;
public string Nombre
{
set
{
nombre = value;
}
get
{
return nombre;
}
}
public int Antiguedad
{
set
{
if (value >= 0)
{
antiguedad = value;
}
else
{
Console.Write("No se puede asignar aun valor
negativo a la antiguedad");
}
}
get
{
return antiguedad;
}
}
}
class Club
{
private Socio socio1, socio2, socio3;
public Club()
{
socio1 = new Socio();
socio1.Nombre = "Juan";
socio1.Antiguedad = 7;
socio2 = new Socio();
socio2.Nombre = "Ana";
socio2.Antiguedad = 3;
socio3 = new Socio();
socio3.Nombre = "Martin";
socio3.Antiguedad = 25;
}
public void MayorAntiguedad()
{
if (socio1.Antiguedad > socio2.Antiguedad &&
socio1.Antiguedad > socio3.Antiguedad)
{
Console.WriteLine("Socio com mayor
antiguedad:"+socio1.Nombre);
}
else
{
if (socio2.Antiguedad > socio3.Antiguedad)
{
Console.WriteLine("Socio com mayor
antiguedad:" + socio2.Nombre);
}
else
{
Console.WriteLine("Socio com mayor
antiguedad:" + socio3.Nombre);
}
}
}
28.- Herencia
Vimos en el concepto anterior que dos clases pueden estar relacionadas por la
colaboracin. Ahora veremos otro tipo de relaciones entre clases que es la
Herencia.
La herencia significa que se pueden crear nuevas clases partiendo de clases
existentes, que tendr todas los atributos, propiedades y los mtodos de su
'superclase' o 'clase padre' y adems se le podrn aadir otros atributos,
propiedades y mtodos propios.
clase padre
Clase de la que desciende o deriva una clase. Las clases hijas (descendientes)
heredan (incorporan) automticamente los atributos, propiedades y mtodos de la la
clase padre.
Subclase
Moto
Auto
FordK
Renault 9
Siempre hacia abajo en la jerarqua hay una especializacin (las subclases aaden
nuevos atributos, propiedades y mtodos.
2) Imaginemos la clase Software. Qu clases podran derivar de ella?
Software
DeAplicacion
ProcesadorTexto
SistemaOperativo
DeBase
PlanillaDeCalculo
Word
WordPerfect
Windows
Excel
Lotus123
Linux
Problema 1:
Ahora plantearemos el primer problema utilizando herencia. Supongamos que
necesitamos implementar dos clases que llamaremos Suma y Resta. Cada clase
tiene como atributo valor1, valor2 y resultado. Las propiedades a definir son Valor1,
Valor2 y Resultado, el mtodo Operar (que en el caso de la clase "Suma" suma los
dos Valores y en el caso de la clase "Resta" hace la diferencia entre Valor1 y
Valor2.
Si analizamos ambas clases encontramos que muchas propiedades son idnticos.
En estos casos es bueno definir una clase padre que agrupe dichas propiedades,
atributos y responsabilidades comunes.
La relacin de herencia que podemos disponer para este problema es:
Operacion
Suma
Resta
Solamente el mtodo operar es distinto para las clases Suma y Resta (esto hace
que no lo podamos disponer en la clase Operacion), luego las propiedades Valor1,
Valor2 son idnticos a las dos clases, esto hace que podamos disponerlos en la
clase Operacion. Lo mismo las propiedades Valor1, Valor2 y Resultado se definirn
en la clase padre Operacion.
Crear un proyecto y luego crear cuatro clases llamadas: Operacion, Suma, Resta y
Prueba
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Herencia1
{
public class Operacion {
protected int valor1;
protected int valor2;
protected int resultado;
public int Valor1
{
set
{
valor1=value;
}
get
{
return valor1;
}
}
public int Valor2
{
set
{
valor2=value;
}
get
{
return valor2;
}
}
public int Resultado
{
protected set
{
resultado=value;
}
get
{
return resultado;
}
}
}
public class Suma: Operacion
{
public void Operar()
{
Resultado=Valor1+Valor2;
}
}
public class Resta: Operacion
{
public void Operar()
{
Resultado=Valor1-Valor2;
}
}
class Prueba
{
static void Main(string[] args)
{
Suma suma1 = new Suma();
suma1.Valor1 = 10;
suma1.Valor2 = 7;
suma1.Operar();
Console.WriteLine("La suma de " +
suma1.Valor1 + " y " +
suma1.Valor2 + " es " +
suma1.Resultado);
Resta resta1 = new Resta();
resta1.Valor1 = 8;
resta1.Valor2 = 4;
resta1.Operar();
Console.WriteLine("La diferencia de " +
resta1.Valor1 +
" y " + resta1.Valor2 + " es " +
resta1.Resultado);
Console.ReadKey();
}
}
}
La clase Operacin define tres atributos y sus tres propiedades que las acceden:
protected int valor1;
protected int valor2;
protected int resultado;
public int Valor1
{
set
{
valor1=value;
}
get
{
return valor1;
}
}
public int Valor2
{
set
{
valor2=value;
}
get
{
return valor2;
}
}
public int Resultado
{
protected set
{
resultado=value;
}
get
{
return resultado;
}
}
Ya veremos que definimos los atributos con este nuevo modificador de acceso
(protected) para que la subclase tenga acceso a dichos atributos. Si los definimos
private las subclases no pueden acceder a dichos atributos.
Ahora veamos como es la sintaxis para indicar que una clase hereda de otra:
public class Suma: Operacion
Podemos llamar tanto al mtodo propio de la clase Suma "Operar()" como acceder
a las propiedades heredadas de la clase Operacion. Quien utilice la clase Suma
solo debe conocer que mtodos y propiedades pblicas tiene (independientemente
que pertenezcan a la clase Suma o a una clase superior)
La lgica es similar para declarar la clase Resta.
La clase Operacin agrupa en este caso un conjunto de atributos y propiedades
comunes a un conjunto de subclases (Suma, Resta). No tiene sentido definir
objetos de la clase Operacion.
El planteo de jerarquas de clases es una tarea compleja que requiere un perfecto
entendimiento de todas las clases que intervienen en un problema, cuales son sus
atributos, propiedades y responsabilidades.
Problema 2:
Confeccionar una clase Persona que tenga como atributos el nombre y la edad
(definir las propiedades para poder acceder a dichos atributos). Definir como
responsabilidad
un
mtodo
para
imprimir.
Plantear una segunda clase Empleado que herede de la clase Persona. Aadir un
atributo sueldo ( y su propiedad) y el mtodo para imprimir su sueldo.
Definir un objeto de la clase Persona y llamar a sus mtodos y propiedades.
Tambin crear un objeto de la clase Empleado y llamar a sus mtodos y
propiedades.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Herencia2
{
public class Persona
{
protected string nombre;
protected int edad;
public string Nombre
{
set
{
nombre = value;
}
get
{
return nombre;
}
}
public int Edad
{
set
{
edad = value;
}
get
{
return edad;
}
}
public void Imprimir()
{
Console.WriteLine("Nombre:" + Nombre);
Console.WriteLine("Edad:" + Edad);
}
}
public class Empleado : Persona
{
protected float sueldo;
public float Sueldo
{
set
{
sueldo = value;
}
get
{
return sueldo;
}
}
new public void Imprimir()
{
base.Imprimir();
Console.WriteLine("Sueldo:" + Sueldo);
}
}
class Prueba
{
static void Main(string[] args)
{
Persona persona1 = new Persona();
persona1.Nombre = "Juan";
persona1.Edad = 25;
Console.WriteLine("Los datos de la
persona son:");
persona1.Imprimir();
Empleado empleado1 = new Empleado();
empleado1.Nombre = "Ana";
empleado1.Edad=42;
empleado1.Sueldo = 2524;
Console.WriteLine("Los dats del
empleado son:");
empleado1.Imprimir();
Console.ReadKey();
}
}
}
La clase Persona define los atributos protegidos (protected) nombre y edad. Luego
las propiedades pblicas Nombre y Edad (que acceden a los atributos para
modificarlos o consultar sus valores.
El mtodo imprimir es pblico para que se lo pueda llamar desde donde definimos
un objeto de esta clase.
public class Persona
{
protected string nombre;
protected int edad;
public string Nombre
{
set
{
nombre = value;
}
get
{
return nombre;
}
}
public int Edad
{
set
{
edad = value;
}
get
{
return edad;
}
}
public void Imprimir()
{
Console.WriteLine("Nombre:" + Nombre);
Console.WriteLine("Edad:" + Edad);
}
}
{
set
{
sueldo = value;
}
get
{
return sueldo;
}
}
new public void Imprimir()
{
base.Imprimir();
Console.WriteLine("Sueldo:" + Sueldo);
}
}
Problema 1:
Plantear tres clases A, B, C que B herede de A y C herede de B. Definir un
constructor a cada clase que muestre un mensaje. Luego definir un objeto de la
clase C.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Herencia3
{
public class A
{
public A()
{
Console.WriteLine("Constructor de la
clase A");
}
}
public class B : A
{
public B()
{
Console.WriteLine("Constructor de la
clase B");
}
}
public class C : B
{
public C()
{
Console.WriteLine("Constructor de la
clase C");
}
}
class Prueba
{
Problema 2:
Plantear tres clases A, B, C que B herede de A y C herede de B. Definir un
constructor a cada clase que reciba como parmetro un entero. Luego definir un
objeto de la clase C.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Herencia4
{
public class A
{
public A(int a)
{
Console.WriteLine(a);
}
}
public class B : A
{
public B(int b):base(b/2)
{
Console.WriteLine(b);
}
}
public class C : B
{
public C(int c):base(c/2)
{
Console.WriteLine(c);
}
}
class Prueba
{
static void Main(string[] args)
{
C obj1 = new C(20);
Console.ReadKey();
}
}
}
Como podemos ver la clase el constructor de la clase C debe llamar en forma
explcita al constructor de la clase padre mediante la palabra clave base con el valor
a pasar (en este ejemplo le pasamos el parmetro c dividido por dos):
public C(int c):base(c/2)
Si ejecutamos el programa podemos ver que aparece por pantalla los nmeros:
5
10
20
Problema 1:
Plantear una clase Rectangulo, definir dos propiedades: Lado1 y Lado2. Definir dos
mtodos RetornarSuperficie y RetornarPerimetro. Dividir la clase en dos archivos
utilizando el concepto de "partial class".
Programa:
Archivo1.cs
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ClaseParcial1
{
partial class Rectangulo
{
private int lado1;
public int Lado1
{
set
{
lado1 = value;
}
get
{
return lado1;
}
}
Archivo2.cs
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ClaseParcial1
{
partial class Rectangulo
{
public int RetornarSuperficie()
{
int sup = Lado1 * Lado2;
return sup;
}
public int RetornarPerimetro()
{
int per = Lado1 * 2 + Lado2 * 2;
return per;
}
}
Program.cs
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ClaseParcial1
{
class Program
{
static void Main(string[] args)
{
Rectangulo rectangulo1 = new
Rectangulo();
rectangulo1.Lado1 = 5;
rectangulo1.Lado2 = 10;
Console.WriteLine("La superficie del
rectngulo es:" +
rectangulo1.RetornarSuperficie());
Console.WriteLine("El permetro del
rectngulo es:" +
rectangulo1.RetornarPerimetro());
Console.ReadKey();
}
}
}
Para codificar este proyecto procedemos de la siguiente forma:
1. Seleccionamos desde el men de opciones Archivo -> Nuevo proyecto...
2. En el dilogo definimos el nombre del proyecto: ClaseParcial1
3. Ahora tenemos que agregar los otros archivos. Presionamos el botn derecho del
mouse en la ventana del "Explorador de soluciones" sobre el nombre del proyecto
("ClaseParcial1") y seleccionamos la opcin Agregar -> Nuevo elemento.
etiqueta
que
muestra
el
botn):
Program.ch
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Windows.Forms;
namespace WindowsFormsApplication1
{
static class Program
{
///
/// Punto de entrada principal para la
aplicacin.
///
[STAThread]
static void Main()
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(f
alse);
Application.Run(new Form1());
}
}
}
Form1.ch
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplication1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
}
}
Form1.Designer.ch
namespace WindowsFormsApplication1
{
partial class Form1
{
///
/// Variable del diseador requerida.
///
private
System.ComponentModel.IContainer components =
null;
///
/// Limpiar los recursos que se estn
utilizando.
///
/// true si los recursos administrados
se deben eliminar; false en caso contrario,
false.
protected override void Dispose(bool
disposing)
{
if (disposing && (components !=
null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Cdigo generado por el
Diseador de Windows Forms
///
/// Mtodo necesario para admitir el
Diseador. No se puede modificar
/// el contenido del mtodo con el
editor de cdigo.
///
private void InitializeComponent()
{
this.button1 = new
System.Windows.Forms.Button();
this.SuspendLayout();
//
// button1
//
this.button1.Location = new
System.Drawing.Point(190, 223);
this.button1.Name = "button1";
this.button1.Size = new
System.Drawing.Size(75, 23);
this.button1.TabIndex = 0;
this.button1.Text = "Hola Mundo";
this.button1.UseVisualStyleBackColor = true;
//
// Form1
//
this.AutoScaleDimensions = new
System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode =
System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new
System.Drawing.Size(292, 273);
this.Controls.Add(this.button1);
this.Name = "Form1";
this.Text = "Form1";
this.ResumeLayout(false);
}
#endregion
private System.Windows.Forms.Button
button1;
}
}
32.- Cuadro de herramientas (Windows Forms)
El cuadro de herramientas contiene todas las componentes visuales que nos
permiten elaborar nuestro formulario.
Podemos ver todos los controles visuales en forma completa:
Problema 1:
: Desarrollar un programa que muestre un objeto de cada una de las siguientes
clases: MonthCalendar, TextBox y Button
La interfaz visual debe ser parecida a esta:
Hasta ahora solo hemos creado una interfaz visual, como podemos ver algunas
componentes en tiempo de ejecucin tienen funcionalidad (el objeto de la clase
MonthCalendar si ejecutamos el programa nos permite seleccionar una fecha,
cambiar de mes etc., el control de la clase TextBox nos permite ingresar una
cadena de caracteres, pero el objeto de la clase Button cuando se presiona
podemos ver que se visualiza que es hundido con el mouse pero no hace nada):
Problema propuesto
1. Elaborar una interfaz grfica que muestre una calculadora (utilizar objetos de
la clase Button y un objeto de la clase TextBox donde se mostraran los
resultados y se cargaran los datos), tener en cuenta que solo se debe
implementar la interfaz y no la funcionalidad de una calculadora.
Problema:
Confeccionar un programa que al presionar un botn se muestre en un objeto de la
clase Label el string "Hola Mundo".
Programa:
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
using System.Windows.Forms;
namespace WindowsFormsApplication5
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
label1.Text = "Hola Mundo";
}
}
}
Hay que tener en cuenta que la clase anterior es parcial (el archivo
Form1.Designer.cs contiene la definicin de los dos objetos y la inicializacin de sus
propiedades y evento):
namespace WindowsFormsApplication5
{
partial class Form1
{
///
/// Variable del diseador requerida.
///
private System.ComponentModel.IContainer
components = null;
///
/// Limpiar los recursos que se estn
utilizando.
///
/// true si los recursos administrados se
deben eliminar;
this.label1.Text = "label1";
//
// button1
//
this.button1.Location = new
System.Drawing.Point(51, 148);
this.button1.Name = "button1";
this.button1.Size = new
System.Drawing.Size(75, 23);
this.button1.TabIndex = 1;
this.button1.Text = "Presionar";
this.button1.UseVisualStyleBackColor =
true;
this.button1.Click += new
System.EventHandler(this.button1_Click);
//
// Form1
//
this.AutoScaleDimensions = new
System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode =
System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new
System.Drawing.Size(292, 273);
this.Controls.Add(this.button1);
this.Controls.Add(this.label1);
this.Name = "Form1";
this.Text = "Form1";
this.ResumeLayout(false);
this.PerformLayout();
}
#endregion
private System.Windows.Forms.Label label1;
private System.Windows.Forms.Button
button1;
}
}
Al ejecutar el programa si presionamos el botn vemos como cambia el contenido
de la Label (esto debido a que en el evento click del botn cambiamos el valor de la
propiedad Text del objeto de la clase Label):
Problema propuesto
1. Disponer 7 objetos de la clase Button con los das de la semana. Fijar en los
atributos Text de cada botn los das de la semana. Al presionar un botn
mostrar en un objeto de la clase Label el da seleccionado.
SOLUCION
using System;
using
using
using
using
using
using
using
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplication6
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
label1.Text = "Lunes";
}
private void button2_Click(object sender, EventArgs e)
{
label1.Text = "Martes";
}
private void button3_Click(object sender, EventArgs e)
{
label1.Text = "Miercoles";
}
private void button4_Click(object sender, EventArgs e)
{
label1.Text = "Jueves";
}
private void button5_Click(object sender, EventArgs e)
{
label1.Text = "Viernes";
}
private void button6_Click(object sender, EventArgs e)
{
label1.Text = "Sbado";
}
Cursor: Definimos el cono del cursor a mostrar cuando disponemos el mouse dentro del
control.
Visible: Determina si el control est visible u oculto cuando ejecutamos el programa.
Problema propuesto
1. Crear una aplicacin que muestre en 6 objetos de la clase Label con algunos nombres
de controles visuales contenidos en la pestaa de "controles comunes" del cuadro de
herramientas
SOLUCION
Problema 1:
Confeccionar un formulario que muestre tres objetos de la clase Button, disponer
como etiqueta en cada botn los valores 1,2 y 3. Cuando se presiona el botn
mostrar en el ttulo del formulario el valor de la etiqueta del botn presionado.
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationButton1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
Text = button1.Text;
}
private void button2_Click(object sender,
EventArgs e)
{
Text = button2.Text;
}
private void button3_Click(object sender,
EventArgs e)
{
Text = button3.Text;
}
}
}
Para el evento click de cada botn inicializamos la propiedad Text del formulario
con la propiedad Text del botn presionado (como la clase Form1 hereda de la
clase Form luego accedemos a la propiedad Text sin anteceder nombre alguno:
Text = button1.Text; ):
private void button1_Click(object sender, EventArgs e)
{
Text = button1.Text;
}
Problema 2:
Modificar el problema anterior para que se acumulen en el ttulo del formulario los
valores de los botones presionados.
Programa:
using System;
using System.Collections.Generic;
using
using
using
using
using
using
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationButton2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
Text = Text + button1.Text;
}
private void button2_Click(object sender,
EventArgs e)
{
Text = Text + button2.Text;
}
private void button3_Click(object sender,
EventArgs e)
{
Text = Text + button3.Text;
}
}
}
Concatenamos el valor actual de la propiedad Text del formulario con el valor de la
propiedad Text del botn respectivo:
private void button1_Click(object sender, EventArgs e)
{
Text = Text + button1.Text;
}
Problema 3:
Similar al problema anterior solo permitir mostrar hasta 10 caracteres en el ttulo del
formulario.
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationButton3
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
if (Text.Length < 10)
{
Text = Text + button1.Text;
}
}
private void button2_Click(object sender,
EventArgs e)
{
Problema propuesto
1. Elaborar una interfaz grfica que muestre una calculadora (utilizar objetos de
la clase Button y un objeto de la clase Label donde se muestra el valor
ingresado), tener en cuenta que solo se debe implementar la interfaz y la
carga
de
un
valor
de
hasta
12
dgitos.
SOLUCION
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationButton4
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button0_Click(object sender, EventArgs e)
{
if (label1.Text.Length < 12)
{
label1.Text = label1.Text + button0.Text;
}
}
private void button1_Click(object sender, EventArgs e)
{
{
if (label1.Text.Length < 12)
{
label1.Text = label1.Text + button7.Text;
}
}
private void button8_Click(object sender, EventArgs e)
{
if (label1.Text.Length < 12)
{
label1.Text = label1.Text + button8.Text;
}
}
private void button9_Click(object sender, EventArgs e)
{
if (label1.Text.Length < 12)
{
label1.Text = label1.Text + button8.Text;
}
}
}
}
Problema 1:
Confeccionar un programa que permita ingresar dos valores enteros por teclado y al
presionar un botn mostrar en una Label la suma de dichos valores.
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationTextBox1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
int valor1 = int.Parse(textBox1.Text);
Problema 2:
Solicitar que se ingrese una clave. Si se ingresa la cadena "abc123" mostrar un
mensaje de clave correcta en caso contrario mostrar clave incorrecta.
Utilizar un control de tipo TextBox para el ingreso de la clave y una Label para mostrar
el resultado al presionar un botn.
Inicializar la propiedad UseSystemPasswordChar con el valor true (esto hace que
cuando el operador tipee caracteres dentro del TextBox se visualicen como asteriscos)
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationTextBox2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
if (textBox1.Text == "abc123")
{
label2.Text = "Clave correcta";
}
else
{
label2.Text = "Clave incorrecta";
}
}
}
}
Para verificar si la clave es correcta comparamos la cadena cargada en el textBox1 con
la cadena "abc123".
Hay otra propiedad en la clase TextBox llamada PasswordChar, si la propiedad
UseSystemPasswordChar esta configurada con false podemos inicializar la propiedad
PasswordChar con el caracter que queremos que se muestre al ingresar datos en el
TextBox. Probar de inicializarlo con el caracter '+' y veremos que en vez de aparecer
asteriscos aparecen caracteres '+'
Problema 3:
Disponer un control de tipo TextBox e inicializar la propiedad Multiline con el valor true
(esto permite ingresar mltiples lneas dentro de un TextBox.
Programa:
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
using System.Windows.Forms;
namespace WindowsFormsApplicationTextBox3
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
MessageBox.Show(textBox2.Text);
}
}
}
Cuando se presiona un botn se muestra en cuadro de mensajes (MessageBox) el
texto ingresado en el textBox2:
MessageBox.Show(textBox2.Text);
Problema propuesto
1. Solicitar el ingreso de una clave de hasta 10 caracteres en un control de tipo TextBox
(inicializar
la
propiedad
MaxLength
con
el
valor
Mostrar en un cuadro de mensajes la clave ingresada al presionar un botn.
SOLUCION
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationTextBox4
{
public partial class Form1 : Form
{
10)
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
MessageBox.Show(textBox1.Text);
}
}
}
Problema 1:
Confeccionar un programa que muestre 3 objetos de la clase CheckBox con
etiquetas de tres idiomas. Cuando se presiona un botn mostrar en la barra de
ttulos del Form todos los CheckBox seleccionados hasta el momento.
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationCheckBox1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
Text = "";
if (checkBox1.Checked == true)
{
Text = Text + "(Ingls)";
}
if (checkBox2.Checked == true)
{
Text = Text + "(Francs)";
}
if (checkBox3.Checked == true)
{
Text = Text + "(Alemn)";
}
}
}
}
La clase CheckBox tiene una propiedad llamada Checked (si tiene el valor true
significa que el CheckBox esta seleccionado, en caso contrario no esta
seleccionado.
En el evento Click del botn primero borramos el contenido del ttulo del Form:
Text = "";
Problema 2:
Disponer un control Label que muestre el siguiente mensaje: "Esta de acuerdo con
las normas del servicio?", luego un CheckBox y finalmente un objeto de tipo Button
desactivo (propiedad Enabled con false). Cuando se tilde el CheckBox debemos
activar el botn (para esto debemos responder al evento)
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationCheckBox2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void
checkBox1_CheckedChanged(object sender, EventArgs
e)
{
if (checkBox1.Checked == true)
{
button1.Enabled = true;
}
else
{
button1.Enabled = false;
}
}
}
}
Debemos implementar el evento CheckedChange del objeto checkBox1
(preguntamos si el CheckBox se encuentra seleccionado o no, en caso de estar
seleccionado activamos el botn asignando a la propiedad Enabled el valor true):
private void checkBox1_CheckedChanged(object sender, EventArgs e)
{
if (checkBox1.Checked == true)
{
button1.Enabled = true;
}
else
{
button1.Enabled = false;
}
}
Problema propuesto
1. Disponer tres objetos de la clase CheckBox con nombres de navegadores
web. Cuando se presione un botn mostrar en el ttulo del Form los
programas seleccionados.
SOLUCION
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationCheckBox3
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
Text = "";
if (checkBox1.Checked == true)
{
Text = Text + "(" + checkBox1.Text + ")";
}
if (checkBox2.Checked == true)
{
Text = Text + "(" + checkBox2.Text + ")";
}
if (checkBox3.Checked == true)
{
Text = Text + "(" + checkBox3.Text + ")";
}
}
}
}
Problema 1:
Confeccionar un programa que muestre 3 objetos de la clase RadioButton que
permitan configurar el ancho y alto del Form. Cuando se presione un botn
actualizar el ancho y alto.
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationRadioButton1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
if (radioButton1.Checked == true)
{
Width = 640;
Height = 480;
}
else
{
if (radioButton2.Checked == true)
{
Width = 800;
Height = 600;
}
else
{
if (radioButton3.Checked ==
true)
{
Width = 1024;
Height = 768;
}
}
}
}
}
}
Todos los controles que se disponen dentro de un Form estn asociados, es decir
que cuando seleccionamos uno se desmarca la actual.
El control RadioButton tiene una propiedad llamada Checked que almacena true o
false, por eso que por medio de un conjunto de if verificamos cual de los radio esta
seleccionado:
if (radioButton1.Checked == true)
{
Width = 640;
Height = 480;
}
else
{
if (radioButton2.Checked == true)
{
Width = 800;
Height = 600;
}
else
{
if (radioButton3.Checked == true)
{
Width = 1024;
Height = 768;
}
}
}
Para cambiar el ancho y alto del Form accedemos a las propiedades Width y
Height.
Problemas propuestos
1. Permitir el ingreso de dos nmeros en controles de tipo TextBox y mediante
dos controles de tipo RadioButton permitir seleccionar si queremos sumarlos
o restarlos. Al presionar un botn mostrar en el ttulo del Form el resultado de
la operacin.
SOLUCION
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationRadioButton2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
int valor1 = int.Parse(textBox1.Text);
int valor2 = int.Parse(textBox2.Text);
if (radioButton1.Checked == true)
{
int suma = valor1 + valor2;
Text = suma.ToString();
}
else
{
if (radioButton2.Checked == true)
{
int resta = valor1 - valor2;
Text = resta.ToString();
}
}
}
}
}
Problema 1:
Cargar en un ComboBox los nombres de varios colores. Al seleccionar alguno mostrar en la
barra de ttulo del Form el string seleccionado.
Programa:
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationComboBox1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void comboBox1_SelectedIndexChanged(object sender, EventArgs
e)
{
Text = comboBox1.Text;
}
}
}
Problema 2:
Disponer tres controles de tipo ComboBox con valores entre 0 y 255 (cada uno representa la
cantidad de rojo, verde y azul). Luego al presionar un botn pintar el fondo del Form con el color
que se genera combinando los valores de los ComboBox.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
using
using
using
using
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationComboBox2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
for (int f = 0; f <= 255; f++)
{
comboBox1.Items.Add(f.ToString());
comboBox2.Items.Add(f.ToString());
comboBox3.Items.Add(f.ToString());
}
comboBox1.SelectedIndex = 0;
comboBox2.SelectedIndex = 0;
comboBox3.SelectedIndex = 0;
}
private void button1_Click(object sender, EventArgs e)
{
int rojo = int.Parse(comboBox1.Text);
int verde = int.Parse(comboBox2.Text);
int azul = int.Parse(comboBox3.Text);
BackColor = Color.FromArgb(rojo, verde, azul);
}
}
}
La carga manual de cada ComboBox nos hara perder mucho tiempo en tiempo de diseo por lo
que lo hacemos mediante un algoritmo. Cuando se carga el Form se ejecuta el evento Load
donde mediante un for procedemos a aadir los 256 valores:
private void Form1_Load(object sender, EventArgs e)
{
for (int f = 0; f <= 255; f++)
{
comboBox1.Items.Add(f.ToString());
comboBox2.Items.Add(f.ToString());
comboBox3.Items.Add(f.ToString());
}
La propiedad Items del ComboBox tiene un mtodo llamado Add que aade un elemento a la
lista (como debemos pasar un string como parmetro convertimos a la variable entera f a string)
Luego para dejar seleccionado por defecto el primer item aadido inicializamos la propiedad
SelectedIndex:
comboBox1.SelectedIndex = 0;
comboBox2.SelectedIndex = 0;
comboBox3.SelectedIndex = 0;
En el evento Click del botn procedemos a extraer el valor seleccionado de cada ComboBox y lo
convertimos a entero:
int rojo = int.Parse(comboBox1.Text);
int verde = int.Parse(comboBox2.Text);
int azul = int.Parse(comboBox3.Text);
Para cambiar el color de fondo del Form actualizamos la propiedad BackColor. El color lo
generamos llamando al mtodo esttico FromArgb de la clase Color:
BackColor = Color.FromArgb(rojo, verde, azul);
Problemas propuestos
1. Solicitar el ingreso del nombre de una persona y seleccionar de un control ComboBox un pas. Al
presionar un botn mostrar en la barra del ttulo del Form el nombre ingresado y el pas
seleccionado.
SOLUCION
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace WindowsFormsApplicationComboBox3
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
Text = textBox1.Text + " - " + comboBox1.Text;
}
}
}
Como decamos, una lista es una secuencia de nodos (en este caso cuatro nodos).
La informacin de los nodos en este caso es un entero y siempre contiene un
puntero
que
guarda
la
direccin
del
siguiente
nodo.
raiz es otro puntero externo a la lista que contiene la direccin del primer nodo.
El estado de una lista vara durante la ejecucin del programa:
Con formato: Fuente: (Predeterminado) Arial,
12.5 pto, Color de fuente: Gris 80%
Tipos de listas.
Segn el mecanismo de insercin y extraccin de nodos en la lista tenemos los
siguientes tipos:
Una lista se comporta como una pila si las inserciones y extracciones las hacemos
por un mismo lado de la lista. Tambin se las llama listas LIFO (Last In First Out ltimo en entrar primero en salir)
Una lista se comporta como una cola si las inserciones las hacemos al final y las
extracciones las hacemos por el frente de la lista. Tambin se las llama listas FIFO
(First In First Out - primero en entrar primero en salir)
Una lista se comporta como genrica cuando las inserciones y extracciones se
realizan
en
cualquier
parte
de
la
lista.
Podemos en algn momento insertar un nodo en medio de la lista, en otro momento
al final, borrar uno del frente, borrar uno del fondo o uno interior, etc.
Luego de realizar la insercin la lista tipo pila queda de esta manera: un nodo con el
valor 10 y raiz apunta a dicho nodo. El puntero del nodo apunta a null ya que no hay
otro nodo despus de este.
Insertamos luego el valor 4: insertar(4)
Ahora el primer nodo de la pila es el que almacena el valor cuatro. raiz apunta a
dicho nodo. Recordemos que raiz es el puntero externo a la lista que almacena la
direccin del primer nodo. El nodo que acabamos de insertar en el campo puntero
guarda la direccin del nodo que almacena el valor 10.
Ahora qu sucede si extraemos un nodo de la pila. Cul se extrae? Como
sabemos en una pila se extrae el ltimo en entrar.
Al extraer de la pila tenemos: extraer()
La
pila
ha
quedado
con
un
nodo.
Hay que tener cuidado que si se extrae un nuevo nodo la pila quedar vaca y no se
podr extraer otros valores (avisar que la pila est vaca)
Problema 1:
Confeccionar una clase que administre una lista tipo pila (se debe poder insertar,
extraer e imprimir los datos de la pila)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListasTipoPila1
{
class Pila
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz;
public Pila()
{
raiz = null;
}
public void Insertar(int x)
{
Nodo nuevo;
nuevo = new Nodo();
nuevo.info = x;
if (raiz == null)
{
nuevo.sig = null;
raiz = nuevo;
}
else
{
nuevo.sig = raiz;
raiz = nuevo;
}
}
public int Extraer()
{
if (raiz != null)
{
int informacion = raiz.info;
raiz = raiz.sig;
return informacion;
}
else
{
return int.MaxValue;
}
}
public void Imprimir()
{
Nodo reco=raiz;
Para declarar un nodo debemos utilizar una clase. En este caso la informacin del
nodo (info) es un entero y siempre el nodo tendr una referencia de tipo Nodo, que
le llamamos sig.
El puntero sig apunta al siguiente nodo o a null en caso que no exista otro nodo.
Este puntero es interno a la lista. Para poder acceder a los atributos los definimos
de tipo public.
Tambin definimos un puntero de tipo Nodo llamado raiz. Este puntero tiene la
direccin del primer nodo de la lista. En caso de estar vaca la lista, raiz apunta a
null (es decir no tiene direccin)
Por ltimo queda enlazar el nodo que acabamos de crear al principio de la lista.
Si la lista est vaca debemos guardar en el campo sig del nodo el valor null para
indicar que no hay otro nodo despus de este, y hacer que raiz apunte al nodo
creado (sabemos si una lista esta vaca si raiz almacena un null)
if (raiz == null)
{
nuevo.sig = null;
raiz = nuevo;
}
Como primera actividad cargamos en el puntero sig del nodo apuntado por nuevo la
direccin de raiz, y posteriormente raiz apunta al nodo que acabamos de crear, que
ser ahora el primero de la lista.
Antes de los enlaces tenemos:
Ahora tenemos:
La lista queda:
El mtodo Extraer:
public int Extraer()
{
if (raiz != null)
{
int informacion = raiz.info;
raiz = raiz.sig;
return informacion;
}
else
{
return int.MaxValue;
}
}
El objetivo del mtodo extraer es retornar la informacin del primer nodo y adems
borrarlo de la lista.
Si la lista no est vaca guardamos en una variable local la informacin del primer
nodo:
int informacion = raiz.info;
Por ltimo expliquemos el mtodo para recorrer una lista en forma completa e
imprimir la informacin de cada nodo:
public void Imprimir()
{
Nodo reco=raiz;
Console.WriteLine("Listado de todos los elementos de la pila.");
while (reco!=null)
{
Console.Write(reco.info+"-");
reco=reco.sig;
}
Console.WriteLine();
}
Definimos un puntero auxiliar reco y hacemos que apunte al primer nodo de la lista:
Nodo reco=raiz;
Disponemos una estructura repetitiva que se repetir mientras reco sea distinto a
null. Dentro de la estructura repetitiva hacemos que reco avance al siguiente nodo:
while (reco!=null)
{
Console.Write(reco.info+"-");
reco=reco.sig;
}
Estamos diciendo que reco almacena la direccin que tiene el puntero sig del nodo
apuntado actualmente por reco.
Grficamente:
Al analizarse la condicin:
while (reco!=null)
Ahora s reco apunta a null y ha llegado el final de la lista (Recordar que el ltimo
nodo de la lista tiene almacenado en el puntero sig el valor null, con el objetivo de
saber que es el ltimo nodo)
Para poder probar esta clase recordemos que debemos definir un objeto de la
misma y llamar a sus mtodos:
Problema 2:
Agregar a la clase Pila un mtodo que retorne la cantidad de nodos y otro que
indique si esta vaca.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListasTipoPila1
{
class Pila
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz;
public Pila()
{
raiz = null;
}
public void Insertar(int x)
{
Nodo nuevo;
nuevo = new Nodo();
nuevo.info = x;
if (raiz == null)
{
nuevo.sig = null;
raiz = nuevo;
}
else
{
nuevo.sig = raiz;
raiz = nuevo;
}
}
public int Extraer()
{
if (raiz != null)
{
int informacion = raiz.info;
raiz = raiz.sig;
return informacion;
}
else
{
return int.MaxValue;
}
}
public void Imprimir()
{
Nodo reco=raiz;
Console.WriteLine("Listado de todos los
elementos de la pila.");
while (reco!=null)
{
Console.Write(reco.info+"-");
reco=reco.sig;
}
Console.WriteLine();
}
public bool Vacia()
{
if (raiz == null)
{
return true;
}
else
{
return false;
}
}
public int Cantidad()
{
int cant = 0;
Nodo reco = raiz;
while (reco != null)
{
cant++;
reco = reco.sig;
}
return cant;
}
static void Main(string[] args)
{
Pila pila1=new Pila();
pila1.Insertar(10);
pila1.Insertar(40);
pila1.Insertar(3);
pila1.Imprimir();
Para probar esta clase en la main creamos un objeto de la clase Pila insertamos
tres enteros:
Pila pila1=new Pila();
pila1.Insertar(10);
pila1.Insertar(40);
pila1.Insertar(3);
cantidad
de
nodos
de
la
lista
Luego mientras el mtodo Vacia nos retorne un false (lista no vaca) procedemos a
llamar al mtodo extraer:
while (pila1.Vacia()==false)
{
Console.WriteLine(pila1.Extraer());
}
Problemas propuestos
1. Agregar un mtodo a la clase Pila que retorne la informacin del primer nodo
de la Pila sin borrarlo.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListasTipoPila1
{
class Pila
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz;
public Pila()
{
raiz = null;
}
public void Insertar(int x)
{
Nodo nuevo;
nuevo = new Nodo();
nuevo.info = x;
if (raiz == null)
{
nuevo.sig = null;
raiz = nuevo;
}
else
{
nuevo.sig = raiz;
raiz = nuevo;
}
}
public int Extraer()
{
if (raiz != null)
{
int informacion = raiz.info;
raiz = raiz.sig;
return informacion;
}
else
{
return int.MaxValue;
}
}
public void Imprimir()
{
Nodo reco=raiz;
Console.WriteLine("Listado de todos los elementos de
la pila.");
while (reco!=null)
{
Console.Write(reco.info+"-");
reco=reco.sig;
}
Console.WriteLine();
}
public bool Vacia()
{
if (raiz == null)
{
return true;
}
else
{
return false;
}
}
public int Cantidad()
{
int cant = 0;
Programa:
archivo: Pila.cs
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Formula
{
class Pila
{
class Nodo
{
public char simbolo;
public Nodo sig;
}
private Nodo raiz;
public Pila()
{
raiz = null;
}
public void Insertar(char x)
{
Nodo nuevo;
nuevo = new Nodo();
nuevo.simbolo = x;
if (raiz == null)
{
nuevo.sig = null;
raiz = nuevo;
}
else
{
nuevo.sig = raiz;
raiz = nuevo;
}
}
public char Extraer()
{
if (raiz != null)
{
char informacion = raiz.simbolo;
raiz = raiz.sig;
return informacion;
}
else
{
return char.MaxValue;
}
}
public bool Vacia()
{
if (raiz == null)
{
return true;
}
else
{
return false;
}
}
}
}
archivo: Form1.cs
using System;
using
using
using
using
using
using
using
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace Formula
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
Pila pila1;
pila1 = new Pila();
string cadena = textBox1.Text;
for (int f = 0; f < cadena.Length; f++)
{
if (cadena.ElementAt(f) == '(' ||
cadena.ElementAt(f) == '[' || cadena.ElementAt(f)
== '{')
{
pila1.Insertar(cadena.ElementAt(f));
}
else
{
if (cadena.ElementAt(f) == ')')
{
if (pila1.Extraer() != '(')
{
Text = "Incorrecta";
return;
}
}
else
{
if (cadena.ElementAt(f) ==
']')
{
if (pila1.Extraer() !=
'[')
{
Text =
"Incorrecta";
return;
}
}
else
{
if (cadena.ElementAt(f)
== '}')
{
if (pila1.Extraer()
!= '{')
{
Text =
"Incorrecta";
return;
}
}
}
}
}
}
if (pila1.Vacia())
{
Text = "Correcta";
}
else
{
Text = "Incorrecta";
}
}
}
}
Primero declaramos y definimos la clase Pila. Almacenamos en cada nodo un
caracter y llamamos al campo de informacin smbolo.
No es necesario implementar los mtodos Imprimir, Cantidad, etc. Porque no se
requieren para este problema.
La clase Formula tiene como atributos: un TextBox y un Button
En el mtodo Click verifica si la frmula estn correctos los parentesis, corchetes y
llaves.
En este analizamos la frmula para verificar si est correctamente balanceada.
En este mtodo es donde est gran parte del algoritmo de este problema.
Mostramos en el titulo del Form si la formula esta correctamente balanceada.
Definimos una pila y extraemos el contenido del TextBox:
Pila pila1;
pila1 = new Pila();
string cadena = textBox1.Text;
if (pila1.Vacia())
{
Text = "Correcta";
}
else
{
Text = "Incorrecta";
}
Es importante entender que la clase Formula utiliza un objeto de la clase Pila para
resolver el algoritmo de verificar el balanceo de la frmula, pero no accede
directamente a los nodos de la lista.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListasTipoCola1
{
class Cola
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz,fondo;
public Cola()
{
raiz=null;
fondo=null;
}
}
return informacion;
}
else
return int.MaxValue;
}
public void Imprimir()
{
Nodo reco=raiz;
Console.WriteLine("Listado de todos los
elementos de la cola.");
while (reco!=null)
{
Console.Write(reco.info+"-");
reco=reco.sig;
}
Console.WriteLine();
}
static void Main(string[] args)
{
Cola cola1=new Cola();
cola1.Insertar(5);
cola1.Insertar(10);
cola1.Insertar(50);
cola1.Imprimir();
Console.WriteLine("Extraemos uno de la
cola:"+cola1.Extraer());
cola1.Imprimir();
Console.ReadKey();
}
}
}
La declaracin del nodo es igual a la clase Pila. Luego definimos dos punteros
externos:
class Nodo
{
public int info;
Debemos enlazar el puntero sig del ltimo nodo con el nodo recin creado:
fondo.sig = nuevo;
Y por ltimo el puntero externo fondo debe apuntar al nodo apuntado por nuevo:
fondo = nuevo;
Con esto ya tenemos correctamente enlazados los nodos en la lista tipo cola. Recordar
que el puntero nuevo desaparece cuando se sale del mtodo insertar, pero el nodo
creado no se pierde porque queda enlazado en la lista.
El funcionamiento del mtodo extraer es similar al de la pila:
public int Extraer ()
{
if (!Vacia ())
{
Luego hacemos:
raiz = null;
fondo = null;
raiz = raiz.sig;
archivo: Cola.cs
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaTipoCola2
{
class Cola
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz, fondo;
public Cola()
{
raiz = null;
fondo = null;
}
public bool Vacia()
{
if (raiz == null)
return true;
else
return false;
}
public void Insertar(int info)
{
Nodo nuevo;
nuevo = new Nodo();
nuevo.info = info;
nuevo.sig = null;
if (Vacia())
{
raiz = nuevo;
fondo = nuevo;
}
else
{
fondo.sig = nuevo;
fondo = nuevo;
}
}
public int Extraer()
{
if (!Vacia())
{
int informacion = raiz.info;
if (raiz == fondo)
{
raiz = null;
fondo = null;
}
else
{
raiz = raiz.sig;
}
return informacion;
}
else
return int.MaxValue;
}
public int Cantidad()
{
int cant = 0;
Nodo reco = raiz;
while (reco != null)
{
cant++;
reco = reco.sig;
}
return cant;
}
}
}
archivo: Form1.cs
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace ListaTipoCola2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender,
EventArgs e)
{
Random ale=new Random();
int estado = 0;
int llegada = 2 + ale.Next(0,2);
int salida = -1;
int cantAtendidas = 0;
Cola cola = new Cola();
for (int minuto = 0; minuto < 600;
minuto++)
{
if (llegada == minuto)
{
if (estado == 0)
{
estado = 1;
salida = minuto + 2 +
ale.Next(0, 3);
}
else
{
cola.Insertar(minuto);
}
llegada = minuto + 2 +
ale.Next(0, 2);
}
if (salida == minuto)
{
estado = 0;
cantAtendidas++;
if (!cola.Vacia())
{
cola.Extraer();
estado = 1;
salida = minuto + 2 +
ale.Next(0, 3);
}
}
}
label1.Text="Atendidos:" +
cantAtendidas.ToString();
label2.Text="En cola" +
cola.Cantidad().ToString();
label3.Text="Minuto llegada:" +
cola.Extraer().ToString();
}
}
}
La clase Cola colabora con la clase Form1. En la clase cola debemos definir como
mnimo los mtodos de Insertar, Extraer, Vaca y Cantidad.
La clase Form1 define tres objetos de la clase Label para mostrar los resultados de la
simulacin.
El mtodo ms importante es el click del botn, veamos las distintas partes de dicho
mtodo:
Random ale=new Random();
int estado = 0;
int llegada = 2 + ale.Next(0,2);
int salida = -1;
int cantAtendidas = 0;
Cola cola = new Cola();
La variable estado almacena un cero si el cajero est libre y un uno cuando est
ocupado.
La variable llegada almacena en que minuto llegar el prximo cliente (debemos
generar un valor entre 2 y 3)
La variable salida almacenar en que minuto terminar el cliente de ser atendido (como
al principio el cajero est vaco inicializamos esta variable con -1)
Llevamos un contador para saber la cantidad de personas atendidas (cantAtendidas)
Luego definimos un objeto de la clase Cola para poder almacenar las personas que
llegan al cajero y se lo encuentran ocupado.
Creamos un objeto de la clase Random para poder utilizar el mtodo Next que nos
retorna un valor aleatorio en el rango que le pasamos como parmetros (si pasamos un
0 y 2 luego nos puede retornar un 0 o un 1)
Disponemos un for que se repita 600 veces (600 minutos o lo que es lo mismo 10
horas)
for (int minuto = 0; minuto < 600; minuto++)
Dentro del for hay dos if fundamentales que verifican que sucede cuando llega una
persona o cuando una persona se retira:
if (llegada == minuto)
{
............
}
if (salida == minuto)
{
............
}
Cuando llega una persona al cajero primero verificamos si el cajero est desocupado:
if (llegada == minuto)
{
if (estado==0)
{
Si est desocupado lo ocupamos cambiando el valor de la variable estado y generando
en que minuto esta persona dejar el cajero (un valor aleatorio entre 2 y 4 minutos):
estado = 1;
salida = minuto + 2 + ale.Next(0, 3);
Si el cajero est ocupado procedemos a cargar dicha persona en la cola (insertamos el
minuto que llega):
else
{
cola.Insertar(minuto);
}
Luego generamos el prximo minuto que llegar otra persona:
llegada = minuto + 2 + ale.Next(0, 2);
El otro if importante es ver que sucede cuando sale la persona del cajero:
if (salida == minuto) {
Problemas propuestos
1. Un supermercado tiene tres cajas para la atencin de los clientes.
Las cajeras tardan entre 7 y 11 minutos para la atencin de cada cliente.
Los clientes llegan a la zona de cajas cada 2 3 minutos. (Cuando el cliente
llega, si todas las cajas tienen 6 personas, el cliente se marcha del
supermercado)
Cuando el cliente llega a la zona de cajas elige la caja con una cola menor.
Realizar una simulacin durante 8 horas y obtener la siguiente informacin:
a
Cantidad
de
clientes
atendidos
por
cada
caja.
b - Cantidad de clientes que se marcharon sin hacer compras.
c - Tiempo promedio en cola.
SOLUCION
Archivo: Cola.cs
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaTipoCola3
{
class Cola
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz, fondo;
public Cola()
{
raiz = null;
fondo = null;
}
public bool Vacia()
{
if (raiz == null)
return true;
else
return false;
}
public void Insertar(int info)
{
Nodo nuevo;
nuevo = new Nodo();
nuevo.info = info;
nuevo.sig = null;
if (Vacia())
{
raiz = nuevo;
fondo = nuevo;
}
else
{
fondo.sig = nuevo;
fondo = nuevo;
}
}
public int Extraer()
{
if (!Vacia())
{
int informacion = raiz.info;
if (raiz == fondo)
{
raiz = null;
fondo = null;
}
else
{
raiz = raiz.sig;
}
return informacion;
}
else
return int.MaxValue;
}
public int Cantidad()
{
int cant = 0;
Nodo reco = raiz;
while (reco != null)
{
cant++;
reco = reco.sig;
}
return cant;
}
}
}
Archivo: Form1.cs
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace ListaTipoCola3
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
Random ale = new Random();
int estado1 = 0, estado2 = 0, estado3 = 0;
int marchan = 0;
int llegada = 2 + ale.Next(0, 2);
int salida1 = -1, salida2 = -1, salida3 = -1;
int cantAte1 = 0, cantAte2 = 0, cantAte3 = 0;
int tiempoEnCola = 0;
int cantidadEnCola = 0;
Cola cola1 = new Cola();
Cola cola2 = new Cola();
Cola cola3 = new Cola();
for (int minuto = 0; minuto < 600; minuto++)
{
if (llegada == minuto)
{
if (estado1 == 0)
{
estado1 = 1;
salida1 = minuto + 7 + ale.Next(0, 5);
}
else
{
if (estado2 == 0)
{
estado2 = 1;
salida2 = minuto + 7 + ale.Next(0,
5);
}
else
{
if (estado3 == 0)
{
estado3 = 1;
salida3 = minuto + 7 +
ale.Next(0, 5);
}
else
{
if (cola1.Cantidad() == 6 &&
cola2.Cantidad() == 6 && cola3.Cantidad() == 6)
{
marchan++;
}
else
{
if (cola1.Cantidad() <=
cola2.Cantidad() && cola1.Cantidad() <= cola3.Cantidad())
{
cola1.Insertar(minuto);
}
else
{
if (cola2.Cantidad() <=
cola3.Cantidad())
{
cola2.Insertar(minuto);
}
else
{
cola3.Insertar(minuto);
}
}
}
}
}
}
llegada = minuto + 2 + ale.Next(0, 2);
}
if (salida1 == minuto)
{
cantAte1++;
estado1 = 0;
if (!cola1.Vacia())
{
estado1 = 1;
int m = cola1.Extraer();
salida1 = minuto + 7 + ale.Next(0, 5);
tiempoEnCola = tiempoEnCola + (minuto m);
cantidadEnCola++;
}
}
if (salida2 == minuto)
{
cantAte2++;
estado2 = 0;
if (!cola2.Vacia())
{
estado2 = 1;
int m = cola2.Extraer();
salida2 = minuto + 7 + ale.Next(0, 5);
tiempoEnCola = tiempoEnCola + (minuto m);
cantidadEnCola++;
}
}
if (salida3 == minuto)
{
cantAte3++;
estado3 = 0;
if (!cola3.Vacia())
{
estado3 = 1;
int m = cola3.Extraer();
salida3 = minuto + 7 + ale.Next(0, 5);
tiempoEnCola = tiempoEnCola + (minuto m);
cantidadEnCola++;
}
}
}
label1.Text="Clientes atendidos por caja: caja1=" +
cantAte1.ToString() + " caja2=" + cantAte2.ToString() + "
caja3=" + cantAte3.ToString();
label2.Text="Se marchan sin hacer compras:" +
marchan.ToString();
if (cantidadEnCola > 0)
{
int tiempoPromedio = tiempoEnCola /
cantidadEnCola;
label3.Text="Tiempo promedio en cola:" +
tiempoPromedio.ToString();
}
}
}
}
cualquier
parte
de
la
lista.
Codificaremos una serie de mtodos para administrar listas genricas.
Mtodos a desarrollar:
Inserta un nodo en la posicin (pos) y con la informacin que hay en el parmetro x.
void Insertar(int pos, int x)
Debe retornar true si la lista est ordenada de menor a mayor, false en caso
contrario.
bool Ordenada()
Debe retornar true si existe la informacin que llega en el parmetro, false en caso
contrario.
bool Existe(int info)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaGenerica1
{
class ListaGenerica
{
class Nodo
{
public int info;
public Nodo sig;
}
nuevo.sig = siguiente;
}
}
}
public int Extraer(int pos)
{
if (pos <= Cantidad())
{
int informacion;
if (pos == 1)
{
informacion = raiz.info;
raiz = raiz.sig;
}
else
{
Nodo reco;
reco = raiz;
for (int f = 1; f <= pos - 2;
f++)
reco = reco.sig;
Nodo prox = reco.sig;
reco.sig = prox.sig;
informacion = prox.info;
}
return informacion;
}
else
return int.MaxValue;
}
public void Borrar(int pos)
{
if (pos <= Cantidad())
{
if (pos == 1)
{
raiz = raiz.sig;
}
else
{
Nodo reco;
reco = raiz;
for (int f = 1; f <= pos - 2;
f++)
reco = reco.sig;
Nodo prox = reco.sig;
reco.sig = prox.sig;
}
}
}
public void Intercambiar(int pos1, int
pos2)
{
if (pos1 <= Cantidad() && pos2 <=
Cantidad())
{
Nodo reco1 = raiz;
for (int f = 1; f < pos1; f++)
reco1 = reco1.sig;
Nodo reco2 = raiz;
for (int f = 1; f < pos2; f++)
reco2 = reco2.sig;
int aux = reco1.info;
reco1.info = reco2.info;
reco2.info = aux;
}
}
public int Mayor()
{
if (!Vacia())
{
int may = raiz.info;
Nodo reco = raiz.sig;
while (reco != null)
{
if (reco.info > may)
may = reco.info;
reco = reco.sig;
}
return may;
}
else
return int.MaxValue;
}
public int PosMayor()
{
if (!Vacia())
{
int may = raiz.info;
int x = 1;
int pos = x;
Nodo reco = raiz.sig;
while (reco != null)
{
if (reco.info > may)
{
may = reco.info;
pos = x;
}
reco = reco.sig;
x++;
}
return pos;
}
else
return int.MaxValue;
}
public int Cantidad()
{
int cant = 0;
Nodo reco = raiz;
while (reco != null)
{
reco = reco.sig;
cant++;
}
return cant;
}
public bool Ordenada()
{
if (Cantidad() > 1)
{
Nodo reco1 = raiz;
Nodo reco2 = raiz.sig;
while (reco2 != null)
{
if (reco2.info < reco1.info)
{
return false;
}
reco2 = reco2.sig;
reco1 = reco1.sig;
}
}
return true;
}
public bool Existe(int x)
{
Nodo reco = raiz;
while (reco != null)
{
if (reco.info == x)
return true;
reco = reco.sig;
}
return false;
}
public bool Vacia()
{
if (raiz == null)
return true;
else
return false;
}
public void Imprimir()
{
Nodo reco = raiz;
while (reco != null) {
Console.Write (reco.info + "-");
reco = reco.sig;
}
Console.WriteLine();
}
static void Main(string[] args)
{
ListaGenerica lg=new ListaGenerica();
lg.Insertar (1, 10);
lg.Insertar (2, 20);
lg.Insertar (3, 30);
lg.Insertar (2, 15);
lg.Insertar (1, 115);
lg.Imprimir ();
Console.WriteLine ("Luego de Borrar el
primero");
lg.Borrar (1);
lg.Imprimir ();
Console.WriteLine ("Luego de Extraer el
segundo");
lg.Extraer (2);
lg.Imprimir ();
Console.WriteLine ("Luego de
Intercambiar el primero con el tercero");
lg.Intercambiar (1, 3);
lg.Imprimir ();
if (lg.Existe(10))
Console.WriteLine("Se encuentra el
20 en la lista");
else
Console.WriteLine("No se encuentra
el 20 en la lista");
Console.WriteLine("La posicin del
mayor es:"+lg.PosMayor());
if (lg.Ordenada())
Console.WriteLine("La lista est
ordenada de menor a mayor");
else
Console.WriteLine("La lista no est
ordenada de menor a mayor");
Console.ReadKey();
}
}
}
Para insertar en una determinada posicin dentro de la lista:
void Insertar (int pos, int x)
Primero con un if verificamos que exista esa posicin en la lista (por ejemplo si la
lista tiene 4 nodos podemos insertar hasta la posicin 5, es decir uno ms all del
ltimo):
if (pos <= Cantidad () + 1)
Si llega un 1 luego enlazamos el puntero sig del nodo que creamos con la direccin
del primer nodo de la lista (raiz apunta siempre al primer nodo de la lista) y luego
desplazamos raiz al nodo que acabamos de crear:
nuevo.sig = raiz;
raiz = nuevo;
y enlazamos el puntero sig del ltimo nodo de la lista con la direccin del nodo que
acabamos de crear (disponemos en sig del nodo creado el valor null ya que no hay
otro nodo ms adelante)
reco.sig = nuevo;
nuevo.sig = null;
Disponemos otro puntero auxiliar que apunte al nodo prximo a donde est
apuntando reco. Ahora enlazamos el puntero sig del nodo apuntado por reco con la
direccin del nodo creado y el puntero sig del nodo creado con la direccin del nodo
siguiente:
Nodo siguiente = reco.sig;
reco.sig = nuevo;
nuevo.sig = siguiente;
Ahora enlazamos el puntero sig del nodo apuntado por reco al nodo siguiente del
nodo apuntado por prox (es decir el nodo apuntado por prox queda fuera de la lista):
reco.sig = prox.sig;
El mtodo intercambiar recibe dos enteros que representan las posiciones de los
nodos que queremos intercambiar sus informaciones:
public void Intercambiar (int pos1, int pos2)
reco1.info = reco2.info;
reco2.info = aux;
Cada vez que encontramos un nodo con informacin mayor que la variable may la
actualizamos con este nuevo valor y avanzamos el puntero reco para visitar el
siguiente nodo:
if (reco.info > may)
may = reco.info;
reco = reco.sig;
El mtodo que retorna la posicin del mayor es similar al anterior con la salvedad
que debemos almacenar en otro auxiliar la posicin donde se almacena el mayor:
public int PosMayor()
{
if (!Vacia ())
{
int may = raiz.info;
int x=1;
int pos=x;
Nodo reco = raiz.sig;
while (reco != null)
{
if (reco.info > may)
{
may = reco.info;
pos=x;
}
reco = reco.sig;
x++;
}
return pos;
}
else
return int.MaxValue;
}
El mtodo que debe retornar si est ordenada la lista de menor a mayor es:
public bool Ordenada()
Disponemos dos punteros auxiliares con las direcciones del primer y segundo nodo
de la lista:
Nodo reco1=raiz;
Nodo reco2=raiz.sig;
Dentro del while avanzamos los dos punteros a sus nodos siguientes
respectivamente.
reco2=reco2.sig;
reco1=reco1.sig;
Fuera del while retornamos true indicando que la lista est ordenada de menor a
mayor
return true;
El mtodo existe:
public bool Existe(int x)
Fuera del while retornamos false indicando que ningn nodo coincide con el
parmetro x:
return false;
Problemas propuestos
1. Plantear una clase para administrar una lista genrica implementando los
siguientes mtodos:
a) Insertar un nodo al principio de la lista.
b) Insertar un nodo al final de la lista.
c) Insertar un nodo en la segunda posicin. Si la lista est vaca no se inserta
el nodo.
d) Insertar un nodo en la ante ltima posicin.
e) Borrar el primer nodo.
f) Borrar el segundo nodo.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaGenerica2
{
class ListaGenerica
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz;
public ListaGenerica()
{
raiz = null;
}
void InsertarPrimero(int x)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
nuevo.sig = raiz;
raiz = nuevo;
}
public void InsertarUtlimo(int x)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz == null)
raiz = nuevo;
else
{
Nodo reco = raiz;
while (reco.sig != null)
{
reco = reco.sig;
}
reco.sig = nuevo;
}
}
public void InsertarSegundo(int x)
{
if (raiz != null)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz.sig == null)
{
//Hay un solo nodo.
raiz.sig = nuevo;
}
else
{
nuevo.sig = raiz.sig;
raiz.sig = nuevo;
}
}
}
public void InsertarAnteUltimo(int x)
{
if (raiz != null)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz.sig == null)
{
//Hay un solo nodo.
nuevo.sig = raiz;
raiz = nuevo;
}
else
{
Nodo atras = raiz;
Nodo reco = raiz.sig;
while (reco.sig != null)
{
atras = reco;
reco = reco.sig;
}
nuevo.sig = atras.sig;
atras.sig = nuevo;
}
}
}
public void BorrarPrimero()
{
if (raiz != null)
{
raiz = raiz.sig;
}
}
public void BorrarSegundo()
{
if (raiz != null)
{
if (raiz.sig != null)
{
Nodo tercero = raiz.sig;
tercero = tercero.sig;
raiz.sig = tercero;
}
}
}
public void BorrarUltimo()
{
if (raiz != null)
{
if (raiz.sig == null)
{
raiz = null;
}
else
{
Nodo reco = raiz.sig;
Nodo atras = reco;
while (reco.sig != null)
{
atras = reco;
reco = reco.sig;
}
atras.sig = null;
}
}
}
}
}
}
}
static void Main(string[] args)
{
ListaGenerica lg=new ListaGenerica();
lg.InsertarPrimero (10);
lg.InsertarPrimero(45);
lg.InsertarPrimero(23);
lg.InsertarPrimero(89);
lg.Imprimir();
Console.WriteLine("Insertamos un nodo al final:");
lg.InsertarUtlimo(160);
lg.Imprimir();
Console.WriteLine("Insertamos un nodo en la segunda
posicin:");
lg.InsertarSegundo(13);
lg.Imprimir();
Console.WriteLine("Insertamos un nodo en la
anteultima posicin:");
lg.InsertarAnteUltimo(600);
lg.Imprimir();
Console.WriteLine("Borramos el primer nodo de la
lista:");
lg.BorrarPrimero();
lg.Imprimir();
Console.WriteLine("Borramos el segundo nodo de la
lista:");
lg.BorrarSegundo();
lg.Imprimir();
Console.WriteLine("Borramos el ultimo nodo de la
lista:");
lg.BorrarUltimo();
lg.Imprimir();
Console.WriteLine("Borramos el mayor de la lista:");
lg.BorrarMayor();
lg.Imprimir();
Console.ReadKey();
}
}
}
listaOrdenada.Insertar(5)
listaOrdenada.Insertar(7)
listaOrdenada.Insertar(50)
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaOrdenada1
{
class ListaOrdenada
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz;
public ListaOrdenada()
{
raiz = null;
}
void Insertar(int x)
{
Nodo nuevo = new Nodo ();
nuevo.info = x;
if (raiz==null)
{
raiz=nuevo;
}
else
{
if (x=reco.info && reco.sig!=null)
{
atras=reco;
reco=reco.sig;
}
if (x>=reco.info)
{
reco.sig=nuevo;
}
else
{
nuevo.sig=reco;
atras.sig=nuevo;
}
}
}
}
public void Imprimir()
{
Nodo reco = raiz;
while (reco != null)
{
Console.Write (reco.info + "-");
reco = reco.sig;
}
Console.WriteLine();
}
static void Main(string[] args)
{
ListaOrdenada lo = new ListaOrdenada();
lo.Insertar(10);
lo.Insertar(5);
lo.Insertar(7);
lo.Insertar(50);
lo.Imprimir();
Console.ReadKey();
}
}
}
El mtodo insertar lo resolvemos de la siguiente forma:
Creamos primeramente el nodo, ya que siempre se insertar la informacin en la
lista:
Nodo nuevo = new Nodo ();
nuevo.info = x;
}
else
{
49.Estructuras
encadenadas
dinmicas:
Listas
genricas
doblemente
A las listas vistas hasta el momento podemos recorrerlas solamente en una direccin
(Listas simplemente encadenadas). Hay problemas donde se requiere recorrer la lista
en ambas direcciones, en estos casos el empleo de listas doblemente encadenadas es
recomendable.
Como ejemplo pensemos que debemos almacenar un men de opciones en una lista,
la opcin a seleccionar puede ser la siguiente o la anterior, podemos desplazarnos en
ambas direcciones.
Representacin grfica de una lista doblemente encadenada:
Observemos que una lista doblemente encadenada tiene dos punteros por cada nodo,
uno
apunta
al
nodo
siguiente
y
otro
al
nodo
anterior.
Seguimos teniendo un puntero (raiz) que tiene la direccin del primer nodo.
El puntero sig del ltimo nodo igual que las listas simplemente encadenadas apunta a
null, y el puntero ant del primer nodo apunta a null.
Se pueden plantear Listas tipo pila, cola y genricas con enlace doble.
Hay que tener en cuenta que el requerimiento de memoria es mayor en las listas
doblemente encadenadas ya que tenemos dos punteros por nodo.
La estructura del nodo es:
class Nodo {
public int info;
public Nodo sig, ant;
}
Resolveremos algunos mtodos para administrar listas genricas empleando listas
doblemente encadenadas para analizar la mecnica de enlace de nodos.
Muchos de los mtodos, para listas simple y doblemente encadenadas no vara, como
por ejemplo: el constructor, Vacia, Cantidad, etc.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaGenericaDoble1
{
class ListaGenericaDoble
{
class Nodo {
public int info;
public Nodo ant,sig;
}
private Nodo raiz;
public ListaGenericaDoble ()
{
raiz=null;
}
void Insertar (int pos, int x)
{
if (pos <= Cantidad () + 1)
{
Nodo nuevo = new Nodo ();
nuevo.info = x;
if (pos == 1)
{
nuevo.sig = raiz;
if (raiz!=null)
raiz.ant=nuevo;
raiz = nuevo;
}
else
if (pos == Cantidad () + 1)
{
Nodo reco = raiz;
while (reco.sig != null)
{
reco = reco.sig;
}
reco.sig = nuevo;
nuevo.ant=reco;
nuevo.sig = null;
}
else
{
Nodo reco = raiz;
for (int f = 1 ; f <= pos - 2
; f++)
reco = reco.sig;
Nodo siguiente = reco.sig;
reco.sig = nuevo;
nuevo.ant=reco;
nuevo.sig = siguiente;
siguiente.ant=nuevo;
}
}
}
public int Extraer (int pos)
{
if (pos <= Cantidad ())
{
int informacion;
if (pos == 1)
{
informacion = raiz.info;
raiz = raiz.sig;
if (raiz!=null)
raiz.ant=null;
}
else
{
Nodo reco;
reco = raiz;
for (int f = 1 ; f <= pos - 2 ;
f++)
reco = reco.sig;
Nodo prox = reco.sig;
reco.sig = prox.sig;
Nodo siguiente=prox.sig;
if (siguiente!=null)
siguiente.ant=reco;
informacion = prox.info;
}
return informacion;
}
else
return int.MaxValue;
}
public void Borrar (int pos)
{
if (pos <= Cantidad ())
{
if (pos == 1)
{
raiz = raiz.sig;
if (raiz!=null)
raiz.ant=null;
}
else
{
Nodo reco;
reco = raiz;
for (int f = 1 ; f <= pos - 2 ;
f++)
reco = reco.sig;
Nodo prox = reco.sig;
prox=prox.sig;
reco.sig = prox;
if (prox!=null)
prox.ant=reco;
}
}
}
public void Intercambiar (int pos1,
{
if (pos1 <= Cantidad () && pos2
Cantidad ())
{
Nodo reco1 = raiz;
for (int f = 1 ; f < pos1 ;
reco1 = reco1.sig;
Nodo reco2 = raiz;
for (int f = 1 ; f < pos2 ;
reco2 = reco2.sig;
int aux = reco1.info;
reco1.info = reco2.info;
reco2.info = aux;
int pos2)
<=
f++)
f++)
}
}
public int Mayor ()
{
if (!Vacia ())
{
int may = raiz.info;
Nodo reco = raiz.sig;
while (reco != null)
{
if (reco.info > may)
may = reco.info;
reco = reco.sig;
}
return may;
}
else
return int.MaxValue;
}
public int PosMayor()
{
if (!Vacia ())
{
int may = raiz.info;
int x=1;
int pos=x;
Nodo reco = raiz.sig;
while (reco != null)
{
if (reco.info > may)
{
may = reco.info;
pos=x;
}
reco = reco.sig;
x++;
}
return pos;
}
else
return int.MaxValue;
}
public int Cantidad ()
{
int cant = 0;
Nodo reco = raiz;
while (reco != null)
{
reco = reco.sig;
cant++;
}
return cant;
}
public bool Ordenada()
{
if (Cantidad() > 1)
{
Nodo reco1=raiz;
Nodo reco2=raiz.sig;
while (reco2!=null)
{
if (reco2.info < reco1.info)
{
return false;
}
reco2=reco2.sig;
reco1=reco1.sig;
}
}
return true;
}
public bool Existe(int x)
{
Nodo reco=raiz;
while (reco!=null)
{
if (reco.info==x)
return true;
reco=reco.sig;
}
return false;
}
public bool Vacia ()
{
if (raiz == null)
return true;
else
return false;
}
public void Imprimir ()
{
Nodo reco = raiz;
while (reco != null)
{
Console.Write (reco.info + "-");
reco = reco.sig;
}
Console.WriteLine();
}
static void Main(string[] args)
{
ListaGenericaDoble lg=new
ListaGenericaDoble();
lg.Insertar (1, 10);
lg.Insertar (2, 20);
lg.Insertar (3, 30);
lg.Insertar (2, 15);
lg.Insertar (1, 115);
lg.Imprimir ();
Console.WriteLine("Luego de Borrar el
primero");
lg.Borrar (1);
lg.Imprimir ();
Console.WriteLine("Luego de Extraer el
segundo");
lg.Extraer (2);
lg.Imprimir ();
Console.WriteLine("Luego de Intercambiar
el primero con el tercero");
lg.Intercambiar (1, 3);
lg.Imprimir ();
if (lg.Existe(10))
Console.WriteLine("Se encuentra el 20
en la lista");
else
Console.WriteLine("No se encuentra el
20 en la lista");
Console.WriteLine("La posicin del mayor
es:"+lg.PosMayor());
if (lg.Ordenada())
Console.WriteLine("La lista est
ordenada de menor a mayor");
else
Console.WriteLine("La lista no est
ordenada de menor a mayor");
Console.ReadKey();
}
}
}
Para insertar en una determinada posicin dentro de la lista:
void Insertar (int pos, int x)
Primero con un if verificamos que exista esa posicin en la lista (por ejemplo si la lista
tiene 4 nodos podemos insertar hasta la posicin 5, es decir uno ms all del ltimo):
if (pos <= Cantidad () + 1)
{
Si ingresa al if ya podemos crear el nodo:
Nodo nuevo = new Nodo ();
nuevo.info = x;
siguiente.ant=nuevo;
El mtodo borrar es muy similar al mtodo extraer con la diferencia de que no retorna
valor:
public void Borrar (int pos)
{
if (pos <= Cantidad ())
{
if (pos == 1)
{
raiz = raiz.sig;
if (raiz!=null)
raiz.ant=null;
}
else
{
Nodo reco;
reco = raiz;
for (int f = 1 ; f <= pos - 2 ; f++)
reco = reco.sig;
Nodo prox = reco.sig;
prox=prox.sig;
reco.sig = prox;
if (prox!=null)
prox.ant=reco;
}
}
}
El mtodo intercambiar recibe dos enteros que representan las posiciones de los nodos
que queremos intercambiar sus informaciones:
public void Intercambiar (int pos1, int pos2)
Mediante un if verificamos que las dos posiciones existan en la lista:
if (pos1 <= Cantidad () && pos2 <= Cantidad ())
{
Definimos un puntero auxiliar llamado reco1, lo inicializamos con la direccin del primer
nodo y mediante un for avanzamos hasta la posicin almacenada en pos1:
Nodo reco1 = raiz;
for (int f = 1 ; f < pos1 ; f++)
reco1 = reco1.sig;
De forma similar con un segundo puntero auxiliar avanzamos hasta la posicin indicada
por pos2:
Nodo reco2 = raiz;
for (int f = 1 ; f < pos2 ; f++)
reco2 = reco2.sig;
Por ltimo intercambiamos las informaciones que almacenan cada nodo:
int aux = reco1.info;
reco1.info = reco2.info;
reco2.info = aux;
El mtodo existe:
public bool Existe(int x)
Mediante un while recorremos la la lista:
Nodo reco=raiz;
while (reco!=null)
{
y en cada nodo que visitamos controlamos si el parmetro x es igual a la informacin
del nodo, en caso afirmativo salimos del mtodo retornando true:
if (reco.info==x)
return true;
reco=reco.sig;
Fuera del while retornamos false indicando que ningn nodo coincide con el parmetro
x:
return false;
Problemas propuestos
1. Plantear una clase para administrar una lista genrica doblemente encadenada
implementando los siguientes mtodos:
a) Insertar un nodo al principio de la lista.
b) Insertar un nodo al final de la lista.
c) Insertar un nodo en la segunda posicin. Si la lista est vaca no se inserta el
nodo.
d) Insertar un nodo en la ante ltima posicin.
e) Borrar el primer nodo.
f) Borrar el segundo nodo.
g) Borrar el ltimo nodo.
h) Borrar el nodo con informacin mayor.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaGenericaDoble2
{
class ListaGenericaDoble
{
class Nodo
{
public int info;
public Nodo ant, sig;
}
private Nodo raiz;
public ListaGenericaDoble()
{
raiz = null;
}
void InsertarPrimero(int x)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
nuevo.sig = raiz;
if (raiz != null)
raiz.ant = nuevo;
raiz = nuevo;
}
public void InsertarUtlimo(int x)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz == null)
raiz = nuevo;
else
{
Nodo reco = raiz;
while (reco.sig != null)
{
reco = reco.sig;
}
reco.sig = nuevo;
nuevo.ant = reco;
}
}
public void InsertarSegundo(int x)
{
if (raiz != null)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz.sig == null)
{
//Hay un solo nodo.
raiz.sig = nuevo;
nuevo.ant = raiz;
}
else
{
Nodo tercero = raiz.sig;
nuevo.sig = tercero;
tercero.ant = nuevo;
raiz.sig = nuevo;
nuevo.ant = raiz;
}
}
}
public void InsertarAnteUltimo(int x)
{
if (raiz != null)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz.sig == null)
{
//Hay un solo nodo.
nuevo.sig = raiz;
raiz = nuevo;
}
else
{
Nodo reco = raiz;
while (reco.sig != null)
{
reco = reco.sig;
}
Nodo anterior = reco.ant;
nuevo.sig = reco;
nuevo.ant = anterior;
anterior.sig = nuevo;
reco.ant = nuevo;
}
}
}
public void BorrarPrimero()
{
if (raiz != null)
{
raiz = raiz.sig;
}
}
public void BorrarSegundo()
{
if (raiz != null)
{
if (raiz.sig != null)
{
Nodo tercero = raiz.sig;
tercero = tercero.sig;
raiz.sig = tercero;
if (tercero != null)
tercero.ant = raiz;
}
}
}
public void BorrarUltimo()
{
if (raiz != null)
{
if (raiz.sig == null)
{
raiz = null;
}
else
{
Nodo reco = raiz;
while (reco.sig != null)
{
reco = reco.sig;
}
reco = reco.ant;
reco.sig = null;
}
}
}
public void Imprimir()
{
Nodo reco = raiz;
while (reco != null)
{
Console.Write(reco.info + "-");
reco = reco.sig;
}
Console.WriteLine();
}
public void BorrarMayor()
{
if (raiz != null)
{
Nodo reco = raiz;
int may = raiz.info;
while (reco != null)
{
if (reco.info > may)
{
may = reco.info;
}
reco = reco.sig;
}
reco = raiz;
while (reco != null)
{
if (reco.info == may)
{
if (reco == raiz)
{
raiz = raiz.sig;
if (raiz != null)
raiz.ant = null;
reco = raiz;
}
else
{
Nodo atras = reco.ant;
atras.sig = reco.sig;
reco = reco.sig;
if (reco != null)
reco.ant = atras;
}
}
else
{
reco = reco.sig;
}
}
}
}
static void Main(string[] args)
{
ListaGenericaDoble lg=new ListaGenericaDoble();
lg.InsertarPrimero (10);
lg.InsertarPrimero(45);
lg.InsertarPrimero(23);
lg.InsertarPrimero(89);
lg.Imprimir();
Console.WriteLine("Insertamos un nodo al final:");
lg.InsertarUtlimo(160);
lg.Imprimir();
Console.WriteLine("Insertamos un nodo en la segunda
posicin:");
lg.InsertarSegundo(13);
lg.Imprimir();
Console.WriteLine("Insertamos un nodo en la
anteultima posicin:");
lg.InsertarAnteUltimo(600);
lg.Imprimir();
Console.WriteLine("Borramos el primer nodo de la
lista:");
lg.BorrarPrimero();
lg.Imprimir();
Console.WriteLine("Borramos el segundo nodo de la
lista:");
lg.BorrarSegundo();
lg.Imprimir();
Console.WriteLine("Borramos el ultimo nodo de la
lista:");
lg.BorrarUltimo();
lg.Imprimir();
Console.WriteLine("Borramos el mayor de la lista:");
lg.BorrarMayor();
lg.Imprimir();
Console.ReadKey();
}
}
}
Observemos que el puntero sig del ltimo nodo apunta al primer nodo. En este tipo
de listas si avanzamos raiz no perdemos la referencia al nodo anterior ya que es un
crculo.
Una lista circular puede tambin ser doblemente encadenada:
El puntero ant del primer nodo apunta al ltimo nodo de la lista y el puntero sig del
ltimo nodo de la lista apunta al primero.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ListaCircular1
{
public class ListaCircular
{
class Nodo
{
public int info;
public Nodo ant, sig;
}
private Nodo raiz;
public ListaCircular()
{
raiz = null;
}
public void InsertarPrimero(int x)
{
Nodo nuevo = new Nodo();
nuevo.info = x;
if (raiz == null)
{
nuevo.sig = nuevo;
nuevo.ant = nuevo;
raiz = nuevo;
}
else
{
raiz = null;
}
else
{
Nodo ultimo = raiz.ant;
raiz = raiz.sig;
ultimo.sig = raiz;
raiz.ant = ultimo;
}
}
else
{
Nodo reco = raiz;
for (int f = 1; f <= pos - 1;
f++)
reco = reco.sig;
Nodo anterior = reco.ant;
reco = reco.sig;
anterior.sig = reco;
reco.ant = anterior;
}
}
}
static void Main(string[] args)
{
ListaCircular lc=new ListaCircular();
lc.InsertarPrimero(100);
lc.InsertarPrimero(45);
lc.InsertarPrimero(12);
lc.InsertarPrimero(4);
Console.WriteLine("Luego de insertar 4
nodos al principio");
lc.Imprimir();
lc.InsertarUltimo(250);
lc.InsertarUltimo(7);
Console.WriteLine("Luego de
nodos al final");
lc.Imprimir();
Console.WriteLine("Cantidad
nodos:"+lc.Cantidad());
Console.WriteLine("Luego de
de la primer posicin:");
lc.Borrar(1);
lc.Imprimir();
Console.WriteLine("Luego de
de la cuarta posicin:");
lc.Borrar(4);
lc.Imprimir();
Console.ReadKey();
}
}
}
insertar 2
de
borrar el
borrar el
Si la lista est vaca luego tanto el puntero sig y ant apuntan a si mismo ya que
debe ser circular (y raiz apunta al nodo creado):
if (raiz==null)
{
nuevo.sig=nuevo;
nuevo.ant=nuevo;
raiz=nuevo;
En caso que la lista no est vaca disponemos un puntero al final de la lista (el
puntero ant del primer nodo tiene dicha direccin):
}
else
{
Nodo ultimo=raiz.ant;
Finalmente hacemos que raiz apunte al nodo creado luego de haber hecho todos
los enlaces:
raiz=nuevo;
Para imprimir la lista ya no podemos disponer un puntero reco que apunte al primer
nodo y que se detenga cuando encuentre un nodo que el atributo sig almacene null.
public void Imprimir ()
Problema 1:
Implementacin de un mtodo recursivo.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Recursividad1
{
public class Recursividad
{
void Repetir()
{
Repetir();
}
static void Main(string[] args)
{
Recursividad re = new Recursividad();
re.Repetir();
}
}
}
La funcin Repetir es recursiva porque dentro de la funcin se llama a s misma.
Cuando ejecuta este programa se bloquear y generar un error.
Analicemos
como
funciona:
Primero se ejecuta la funcin Main, luego de crear un objeto llamamos a la funcin
Repetir.
Hay que tener en cuenta que cada vez que se llama a una funcin se reservan 4
bytes de la memoria que se liberarn cuando finalice su ejecucin.
La primera lnea de la funcin llama a la funcin Repetir, es decir que se reservan 4
bytes nuevamente. Se ejecuta nuevamente una instancia de la funcin Repetir y as
sucesivamente hasta que la pila esttica se colme y se cuelgue el programa.
Problema 2:
Implementacin de un mtodo recursivo que reciba un parmetro de tipo entero y
luego llame en forma recursiva con el valor del parmetro menos 1.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Recursividad2
{
public class Recursividad
{
void Imprimir(int x)
{
Console.Write(x + " ");
Imprimir(x - 1);
}
static void Main(string[] args)
{
Recursividad re = new Recursividad();
re.Imprimir(5);
}
}
}
Desde la Main se llama a la funcin Imprimir y se le enva el valor 5. El parmetro x
recibe el valor 5. Se ejecuta el algoritmo de la funcin, imprime el contenido del
parmetro (5) y seguidamente se llama a una funcin, en este caso a s misma (por
eso decimos que es una funcin recursiva), envindole el valor 4.
El parmetro x recibe el valor 4 y se imprime en pantalla el cuatro, llamando
nuevamente
a
la
funcin
imprimir
envindole
el
valor
3.
Si continuamos este algoritmo podremos observar que en pantalla se imprime:
5 4 3 2 1 0 1 2 3
. . . . . . . . .
hasta
que
se
bloquee
el
programa.
Tener en cuenta que cada llamada a una funcin consume 4 bytes por la llamada y
en este caso 4 bytes por el parmetro x. Como nunca finaliza la ejecucin completa
de las funciones se desborda la pila esttica por las sucesivas llamadas.
Problema 3:
Problema 4:
Imprimir los nmeros de 1 a 5 en pantalla utilizando recursividad.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Recursividad4
{
public class Recursividad
{
void Imprimir(int x)
{
if (x > 0)
{
Imprimir(x - 1);
Console.WriteLine(x);
}
}
static void Main(string[] args)
{
Recursividad re = new Recursividad();
re.Imprimir(5);
Console.ReadKey();
}
}
}
Con este ejemplo se presenta una situacin donde debe analizarse lnea a lnea la
ejecucin del programa y el porque de estos resultados.
Por qu se imprime en pantalla 1 2 3 4 5 ?
Veamos como se apilan las llamadas recursivas:
En la primera llamada desde la funcin main el parmetro x recibe el valor 5.
void Imprimir(int x)
{
if (x > 0)
{
Imprimir(x - 1);
Console.WriteLine(x);
}
}
Cuando x vale 0 la condicin del if se vala como falsa y sale de la funcin Imprimir.
Qu
lnea
ahora
se
ejecuta
?
Vuelve a la funcin Main ? NO.
Recordemos que la ltima llamada de la funcin Imprimir se haba hecho desde la
misma funcin Imprimir por lo que vuelve a la lnea:
Console.WriteLine(x);
Problema 5:
Otro problema tpico que se presenta para analizar la recursividad es el obtener el
factorial
de
un
nmero.
Recordar que el factorial de un nmero es el resultado que se obtiene de multiplicar
dicho nmero por el anterior y as sucesivamente hasta llegar a uno.
Ej. el factorial de 4 es 4 * 3 * 2 * 1 es decir 24.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Recursividad5
{
public class Recursividad
{
int Factorial(int fact)
{
if (fact > 0)
{
int valor = fact * Factorial(fact 1);
return valor;
}
else
return 1;
}
static void Main(string[] args)
{
Recursividad re=new Recursividad();
int f=re.Factorial(4);
Console.WriteLine("El factorial de 4 es
"+f);
Console.ReadKey();
}
}
}
La funcin factorial es recursiva porque desde la misma funcin llamamos a la
funcin
Factorial.
Debemos hacer el seguimiento del problema para analizar como se calcula.
La memoria en la primera llamada:
fact recibe el valor 4 y valor se cargar con el valor que se obtenga con el producto
de fact por el valor devuelto por la funcin Factorial (llamada recursiva)
Cuando fact recibe un cero la condicin del if se vala como falsa y ejecuta el else
retornando un 1, la variable local de la llamada anterior a la funcin queda de la
siguiente manera:
Problema 6:
Implementar un mtodo recursivo para ordenar los elementos de un vector.
Programa:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Recursividad6
{
class Recursivdad
{
int[] vec = { 312, 614, 88, 22, 54 };
void Ordenar(int[] v, int cant)
{
if (cant > 1)
{
for (int f = 0; f < cant - 1; f++)
{
if (v[f] > v[f + 1])
{
int aux = v[f];
v[f] = v[f + 1];
v[f + 1] = aux;
}
}
Ordenar (v, cant - 1);
}
}
void Procesar()
{
Ordenar(vec, vec.Length);
}
void Imprimir()
{
for (int f = 0 ; f < vec.Length ; f++)
Console.WriteLine (vec [f] + " ");
Console.WriteLine();
}
Problema 1:
Imprimir la informacin de una lista simplemente encadenada de atrs para adelante.
El empleo de estructuras repetitivas para resolver este problema es bastante engorroso
y lento (debemos avanzar hasta el ltimo nodo e imprimir, luego avanzar desde el
principio hasta el anteltimo nodo y as sucesivamente)
El empleo de la recursividad para este problema hace ms sencillo su solucin.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Recursividad7
{
public class Recursividad
{
class Nodo
{
public int info;
public Nodo sig;
}
private Nodo raiz;
void InsertarPrimero(int x)
{
Nodo nuevo = new Nodo ();
nuevo.info = x;
nuevo.sig=raiz;
raiz=nuevo;
}
private void ImprimirInversa(Nodo reco)
{
if (reco!=null)
{
ImprimirInversa(reco.sig);
Console.Write(reco.info+"-");
}
}
public void ImprimirInversa ()
{
ImprimirInversa(raiz);
}
static void Main(string[] args)
{
Recursividad r=new Recursividad();
r.InsertarPrimero (10);
r.InsertarPrimero(4);
r.InsertarPrimero(5);
r.ImprimirInversa();
Console.ReadKey();
}
}
}
Cuando llamamos al mtodo recursivo le enviamos raiz y el parmetro reco recibe esta
direccin. Si reco es distinto a null llamamos recursivamente al mtodo envindole la
direccin
del
puntero
sig
del
nodo.
Por lo que el parmetro reco recibe la direccin del segundo nodo.
Podemos observar como en las distintas llamadas recursivas el parmetro reco apunta
a un nodo. Cuando se van desapilando las llamadas recursivas se imprime
primeramente el 10 luego el 4 y por ltimo el 5.
Problema 2:
Recorrer un rbol de directorios en forma recursiva.
Programa:
using
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
System.IO;
namespace Recursividad8
{
public class Recursividad
{
public void Leer(string inicio)
{
String[]
archivos=Directory.GetFiles(inicio);
Console.WriteLine(inicio + "
(Directorio)");
for(int f=0;f < archivos.Length;f++)
{
Console.WriteLine(archivos[f]+"
(Archivo)");
}
String[]directorios=Directory.GetDirectories(inicio);
for(int f=0;f < directorios.Length;f++)
{
Leer(directorios[f]);
}
}
static void Main(string[] args)
{
Recursividad rec = new Recursividad();
rec.Leer("c:\\6\\");
Console.WriteLine();
Console.ReadKey();
}
}
}
Debemos importar el espacio de nombres System.IO (donde se encuentra la clase
Directory):
using System.IO;
Para recorrer y visitar todos los directorios y archivos de un directorio debemos
implementar un algoritmo recursivo que reciba como parmetro el directorio inicial
donde comenzaremos a recorrer:
public void Leer(string inicio)
El mtodo esttico GetFiles de la clase Directory retorna todos los archivos contenidos
en la carpeta que le pasamos como parmetro. Seguidamente imprimimos todos los
archivos:
String[] archivos=Directory.GetFiles(inicio);
Console.WriteLine(inicio + " (Directorio)");
for(int f=0;f < archivos.Length;f++)
{
Console.WriteLine(archivos[f]+" (Archivo)");
}
Ahora obtenemos todos los directorios contenidos en la carpeta actual y llamamos en
forma recursiva para cada directorio:
String[]directorios=Directory.GetDirectories(inicio);
for(int f=0;f < directorios.Length;f++)
{
Leer(directorios[f]);
}
Problema 3:
Desarrollar un programa que permita recorrer un laberinto e indique si tiene salida o no.
Para resolver este problema al laberinto lo representaremos con una matriz de 10 x 10
Label.
El valor:
"0"
Representa pasillo
"1"
Representa pared
"9"
Persona
"s"
Salida
A la salida ubicarla en la componente de la fila 9 y columna 9 de la matriz. La persona
comienza a recorrer el laberinto en la fila 0 y columna 0. Los ceros y unos disponerlos
en forma aleatoria
Programa:
archivo: Form1.Designer.cs
namespace Laberinto
{
partial class Form1
{
///
/// Variable del diseador requerida.
///
private System.ComponentModel.IContainer
components = null;
///
/// Limpiar los recursos que se estn
utilizando.
///
/// true si los recursos administrados se
deben eliminar; false en caso contrario, false.
protected override void Dispose(bool
disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Cdigo generado por el Diseador de
Windows Forms
///
/// Mtodo necesario para admitir el
Diseador. No se puede modificar
/// el contenido del mtodo con el editor de
cdigo.
///
private void InitializeComponent()
{
this.button1 = new
System.Windows.Forms.Button();
this.button2 = new
System.Windows.Forms.Button();
this.SuspendLayout();
//
// button1
//
this.button1.Location = new
System.Drawing.Point(11, 15);
this.button1.Name = "button1";
this.button1.Size = new
System.Drawing.Size(75, 23);
this.button1.TabIndex = 0;
this.button1.Text = "Verificar";
this.button1.UseVisualStyleBackColor =
true;
this.button1.Click += new
System.EventHandler(this.button1_Click);
//
// button2
//
this.button2.Location = new
System.Drawing.Point(93, 15);
this.button2.Name = "button2";
this.button2.Size = new
System.Drawing.Size(124, 23);
this.button2.TabIndex = 1;
this.button2.Text = "Otro laberinto";
this.button2.UseVisualStyleBackColor =
true;
this.button2.Click += new
System.EventHandler(this.button2_Click);
//
// Form1
//
this.AutoScaleDimensions = new
System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode =
System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new
System.Drawing.Size(345, 428);
this.Controls.Add(this.button2);
this.Controls.Add(this.button1);
this.Name = "Form1";
this.Text = "Form1";
this.Load += new
System.EventHandler(this.Form1_Load);
this.ResumeLayout(false);
}
#endregion
private System.Windows.Forms.Button button1;
private System.Windows.Forms.Button button2;
}
}
archivo: Form1.cs
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace Laberinto
{
public partial class Form1 : Form
{
private Label[,] mat;
private bool salida;
public Form1()
{
InitializeComponent();
}
mat[f,c].Text="1";
else
mat[f,c].Text="0";;
}
}
mat[9,9].Text="s";
mat[0,0].Text="0";
}
private void Recorrer(int fil, int col)
{
if (fil >= 0 && fil < 10 && col >= 0 &&
col < 10 && salida == false)
{
if (mat[fil,col].Text=="s")
salida = true;
else
if (mat[fil,col].Text=="0")
{
mat[fil,col].Text="9";
mat[fil,col].BackColor=Color.Red;
Recorrer(fil, col
Recorrer(fil + 1,
Recorrer(fil - 1,
Recorrer(fil, col
}
}
}
+ 1);
col);
col);
- 1);
Problemas propuestos
1. Desarrollar el juego del Buscaminas. Definir una matriz de 10*10 de Button y
disponer una 'b' para las bombas (10 diez) un cero en los botones que no tienen
bombas en su permetro, un 1 si tiene una bomba en su permetro y as
sucesivamente. Cuando se presiona un botn si hay un cero proceder en forma
recursiva a destapar los botones que se encuentran a sus lados. Disponer el mismo
color de frente y fondo de los botones para que el jugador no pueda ver si hay
bombas o no.
2. archivo: Form1.Designer.cs
3.
4.
5. namespace Buscaminas
6. {
7.
partial class Form1
8.
{
9.
///
10.
/// Variable del diseador requerida.
11.
///
12.
private System.ComponentModel.IContainer
components = null;
13.
14.
///
15.
/// Limpiar los recursos que se estn
utilizando.
16.
///
17.
/// true si los recursos administrados se
deben eliminar; false en caso contrario, false.
18.
protected override void Dispose(bool
disposing)
19.
{
20.
if (disposing && (components != null))
21.
{
22.
components.Dispose();
23.
}
24.
base.Dispose(disposing);
25.
}
26.
27.
#region Cdigo generado por el Diseador de
Windows Forms
28.
29.
///
30.
/// Mtodo necesario para admitir el
Diseador. No se puede modificar
31.
/// el contenido del mtodo con el editor de
cdigo.
32.
///
33.
private void InitializeComponent()
34.
{
35.
this.button1 = new
System.Windows.Forms.Button();
36.
this.SuspendLayout();
37.
//
38.
// button1
39.
//
40.
this.button1.Location = new
System.Drawing.Point(13, 13);
41.
this.button1.Name = "button1";
42.
this.button1.Size = new
System.Drawing.Size(75, 23);
43.
this.button1.TabIndex = 0;
44.
this.button1.Text = "Reiniciar";
45.
this.button1.UseVisualStyleBackColor =
true;
46.
this.button1.Click += new
System.EventHandler(this.button1_Click);
47.
//
48.
// Form1
49.
//
50.
this.AutoScaleDimensions = new
System.Drawing.SizeF(6F, 13F);
51.
this.AutoScaleMode =
System.Windows.Forms.AutoScaleMode.Font;
52.
this.ClientSize = new
System.Drawing.Size(496, 448);
53.
this.Controls.Add(this.button1);
54.
this.Name = "Form1";
55.
this.Text = "Form1";
56.
this.Load += new
System.EventHandler(this.Form1_Load);
57.
this.ResumeLayout(false);
58.
59.
}
60.
61.
#endregion
62.
63.
private System.Windows.Forms.Button button1;
64.
}
65.
}
66.
67.
68.
69.
archivo: Form1.cs
70.
71.
72.
using System;
73.
using System.Collections.Generic;
74.
using System.ComponentModel;
75.
using System.Data;
76.
using System.Drawing;
77.
using System.Linq;
78.
using System.Text;
79.
using System.Windows.Forms;
80.
81.
namespace Buscaminas
82.
{
83.
public partial class Form1 : Form
84.
{
85.
private Button[,] mat;
86.
87.
public Form1()
88.
{
89.
InitializeComponent();
90.
}
91.
92.
private void Form1_Load(object sender,
EventArgs e)
93.
{
94.
int x = 10;
95.
int y = 50;
96.
mat = new Button[10, 10];
97.
for (int fil = 0; fil <
mat.GetLength(0); fil++)
98.
{
99.
for (int col = 0; col <
mat.GetLength(1); col++)
100.
{
101.
mat[fil, col] = new Button();
102.
mat[fil, col].Text = "0";
103.
mat[fil, col].Location = new
Point(x, y);
104.
mat[fil, col].Size = new
Size(30, 30);
105.
mat[fil, col].Click +=
Presionado;
106.
Controls.Add(mat[fil, col]);
107.
x = x + 30;
108.
}
109.
y = y + 30;
110.
x = 10;
111.
}
112.
Reiniciar();
113.
}
114.
115.
void Reiniciar()
116.
{
117.
Text="";
118.
for (int f = 0; f < 10; f++)
119.
{
120.
for (int c = 0; c < 10; c++)
121.
{
122.
mat[f,c].Text="0";
123.
mat[f,c].Enabled = true; ;
124.
mat[f,c].ForeColor=Color.LightGray;
125.
mat[f,c].BackColor=Color.LightGray;
126.
}
127.
}
128.
DisponerBombas();
129.
ContarBombasPerimetro();
130.
}
131.
132.
void DisponerBombas()
133.
{
134.
int cantidad = 10;
135.
Random ale = new Random();
136.
do
137.
{
138.
int fila = ale.Next(0, 10);
139.
int columna = ale.Next(0, 10);
140.
if (mat[fila,columna].Text!="b")
141.
{
142.
mat[fila,columna].Text="b";
143.
cantidad--;
144.
}
145.
}
146.
while (cantidad != 0);
147.
}
148.
149.
void ContarBombasPerimetro()
150.
{
151.
for (int f = 0; f < 10; f++)
152.
{
153.
for (int c = 0; c < 10; c++)
154.
{
155.
if (mat[f,c].Text=="0")
156.
{
157.
int cant =
ContarCoordenada(f, c);
158.
mat[f,c].Text=cant.ToString();
159.
}
160.
}
161.
}
162.
}
163.
164.
int ContarCoordenada(int fila, int columna)
165.
{
166.
167.
168.
169.
1].Text=="b")
170.
171.
172.
173.
174.
175.
176.
177.
178.
179.
1].Text=="b")
180.
181.
182.
183.
184.
185.
186.
187.
188.
189.
190.
1].Text=="b")
191.
192.
193.
194.
195.
196.
197.
198.
199.
200.
1].Text=="b")
201.
202.
203.
204.
205.
206.
207.
208.
int total = 0;
if (fila - 1 >= 0 && columna - 1 >= 0)
{
if (mat[fila - 1,columna total++;
}
if (fila - 1 >= 0)
{
if (mat[fila - 1,columna].Text=="b")
total++;
}
if (fila - 1 >= 0 && columna + 1 < 10)
{
if (mat[fila - 1,columna +
total++;
}
if (columna + 1 < 10)
{
if (mat[fila,columna + 1].Text=="b")
total++;
}
if (fila + 1 < 10 && columna + 1 < 10)
{
if (mat[fila + 1,columna +
total++;
}
if (fila + 1 < 10)
{
if (mat[fila + 1,columna].Text=="b")
total++;
}
if (fila + 1 < 10 && columna - 1 >= 0)
{
if (mat[fila + 1,columna total++;
}
if (columna - 1 >= 0)
{
if (mat[fila,columna - 1].Text=="b")
total++;
}
return total;
209.
}
210.
211.
private void button1_Click(object sender,
EventArgs e)
212.
{
213.
Reiniciar();
214.
}
215.
216.
private void Presionado(object sender,
EventArgs e)
217.
{
218.
for (int f = 0; f < 10; f++)
219.
{
220.
for (int c = 0; c < 10; c++)
221.
{
222.
if (sender == mat[f,c])
223.
{
224.
if (mat[f,c].Text=="b")
225.
{
226.
Text="Boooooooooooooomm";
227.
DesactivarJuego();
228.
}
229.
else
230.
if (mat[f,c].Text=="0")
231.
{
232.
Recorrer(f, c);
233.
}
234.
else
235.
if
(mat[f,c].Text=="1" ||
236.
mat[f,c].Text=="2" ||
237.
mat[f,c].Text=="3" ||
238.
mat[f,c].Text=="4" ||
239.
mat[f,c].Text=="5" ||
240.
mat[f,c].Text=="6" ||
241.
mat[f,c].Text=="7" ||
242.
mat[f,c].Text=="8")
243.
{
244.
mat[f,c].BackColor=Color.Yellow;
245.
mat[f,c].ForeColor=Color.Black;
246.
}
247.
}
248.
}
249.
}
250.
VerificarTriunfo();
251.
}
252.
253.
void DesactivarJuego()
254.
{
255.
for (int f = 0; f < 10; f++)
256.
{
257.
for (int c = 0; c < 10; c++)
258.
{
259.
mat[f,c].Enabled=false;
260.
}
261.
}
262.
}
263.
264.
void VerificarTriunfo()
265.
{
266.
int cant = 0;
267.
for (int f = 0; f < 10; f++)
268.
{
269.
for (int c = 0; c < 10; c++)
270.
{
271.
Color col = mat[f,c].BackColor;
272.
if (col == Color.Yellow)
273.
cant++;
274.
}
275.
}
276.
if (cant == 90)
277.
{
278.
Text="Ganooooooooo";
279.
DesactivarJuego();
280.
}
281.
}
282.
283.
void Recorrer(int fil, int col)
284.
{
285.
if (fil >= 0 && fil < 10 && col >= 0 &&
col < 10)
286.
{
287.
if (mat[fil,col].Text=="0")
288.
{
289.
mat[fil,col].Text=" ";
290.
mat[fil,col].BackColor=Color.Yellow;
291.
Recorrer(fil, col + 1);
292.
Recorrer(fil, col - 1);
293.
Recorrer(fil + 1, col);
294.
Recorrer(fil - 1, col);
295.
Recorrer(fil - 1, col - 1);
296.
Recorrer(fil - 1, col + 1);
297.
Recorrer(fil + 1, col + 1);
298.
Recorrer(fil + 1, col - 1);
299.
}
300.
else
301.
if (mat[fil,col].Text=="1" ||
302.
mat[fil,col].Text == "2" ||
303.
mat[fil,col].Text == "3" ||
304.
mat[fil,col].Text == "4" ||
305.
mat[fil,col].Text == "5" ||
306.
mat[fil,col].Text == "6" ||
307.
mat[fil,col].Text == "7" ||
308.
mat[fil,col].Text == "8")
309.
{
310.
mat[fil,col].BackColor=Color.Yellow;
311.
mat[fil,col].ForeColor=Color.Black;
312.
}
313.
}
314.
}
315.
}
316.
}
rbol binario completo: Es un rbol binario con hojas como mximo en los niveles n-1
y n (Siendo n el nivel del rbol)
Los dos rboles graficados son completos porque son rboles de nivel 3 y hay nodos
hoja en el nivel 3 en el primer caso, y hay nodos hoja en los niveles 3 y 2 en el segundo
caso.
Ej. rbol binario no completo:
Hay nodos hoja en los niveles 4, 3 y 2. No debera haber nodos hojas en el nivel 2.
rbol binario ordenado: Si para cada nodo del rbol, los nodos ubicados a la
izquierda son inferiores al que consideramos raz para ese momento y los nodos
ubicados a la derecha son mayores que la raz.
Ej.
Analicemos
si
se
trata
de
un
rbol
binario
ordenado:
Para
el
nodo
que
tiene
el
50:
Los nodos del subrbol izquierdo son todos menores a 50? 8, 25, 30 Si
Los nodos del subrbol derecho son todos mayores a 50? 70 Si.
Para
el
nodo
que
tiene
el
25:
Los nodos del subrbol izquierdo son todos menores a 25? 8 Si
Los nodos del subrbol derecho son todos mayores a 25? 30 Si.
No hace falta analizar los nodos hoja. Si todas las respuestas son afirmativas podemos
luego decir que se trata de un rbol binario ordenado.
Insertamos el 400
Insertamos el valor 100. Debemos analizar si raz es distinto a null verificamos si 100
es mayor o menor a la informacin del nodo apuntado por raz, en este caso es menor
y como el subrbol izquierdo es null debemos insertarlo all.
Insertamos el 200. Hay que tener en cuenta que siempre comenzamos las
comparaciones a partir de raz. El 200 es menor que 400, descendemos por el subrbol
izquierdo. Luego analizamos y vemos que el 200 es mayor a 100, debemos avanzar
por derecha. Como el subrbol derecho es null lo insertamos en dicha posicin.
Como podemos observar si cada vez que insertamos un nodo respetamos este
algoritmo siempre estaremos en presencia de un rbol binario ordenado.
Posteriormente veremos el algoritmo en java para la insercin de informacin en el
rbol.
Entre-orden
- Recorrer el subrbol izquierdo en entre-orden.
- Visitar la raz.
- Recorrer el subrbol derecho en entre-orden.
Post-orden
- Recorrer el subrbol izquierdo en post-orden.
- Recorrer el subrbol derecho en post-orden.
- Visitar la raz.
Ejemplo:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ArbolBinarioOrdenado1
{
public class ArbolBinarioOrdenado {
class Nodo
{
public int info;
public Nodo izq, der;
}
Nodo raiz;
public ArbolBinarioOrdenado()
{
raiz=null;
}
public void Insertar (int info)
{
Nodo nuevo;
nuevo = new Nodo ();
nuevo.info = info;
nuevo.izq = null;
nuevo.der = null;
if (raiz == null)
raiz = nuevo;
else
{
Nodo anterior = null, reco;
reco = raiz;
while (reco != null)
{
anterior = reco;
if (info < reco.info)
reco = reco.izq;
else
reco = reco.der;
}
if (info < anterior.info)
anterior.izq = nuevo;
else
anterior.der = nuevo;
}
}
private void ImprimirPre (Nodo reco)
{
if (reco != null)
{
Console.Write(reco.info + " ");
ImprimirPre (reco.izq);
ImprimirPre (reco.der);
}
}
public void ImprimirPre ()
{
ImprimirPre (raiz);
Console.WriteLine();
}
private void ImprimirEntre (Nodo reco)
{
if (reco != null)
{
ImprimirEntre (reco.izq);
Console.Write(reco.info + " ");
ImprimirEntre (reco.der);
}
}
public void ImprimirEntre ()
{
ImprimirEntre (raiz);
Console.WriteLine();
}
private void ImprimirPost (Nodo reco)
{
if (reco != null)
{
ImprimirPost (reco.izq);
ImprimirPost (reco.der);
Console.Write(reco.info + " ");
}
}
public void ImprimirPost ()
{
ImprimirPost (raiz);
Console.WriteLine();
}
static void Main(string[] args)
{
ArbolBinarioOrdenado abo = new
ArbolBinarioOrdenado ();
abo.Insertar (100);
abo.Insertar (50);
abo.Insertar (25);
abo.Insertar (75);
abo.Insertar (150);
Console.WriteLine ("Impresion preorden:
");
abo.ImprimirPre ();
Console.WriteLine ("Impresion entreorden:
");
abo.ImprimirEntre ();
Console.WriteLine ("Impresion postorden:
");
abo.ImprimirPost ();
Console.ReadKey();
}
}
}
public void Insertar (int info)
{
Nodo nuevo;
nuevo = new Nodo ();
nuevo.info = info;
nuevo.izq = null;
nuevo.der = null;
if (raiz == null)
raiz = nuevo;
else
{
Nodo anterior = null, reco;
reco = raiz;
while (reco != null)
{
anterior = reco;
if (info < reco.info)
reco = reco.izq;
else
reco = reco.der;
}
if (info < anterior.info)
anterior.izq = nuevo;
else
anterior.der = nuevo;
}
}
Creamos un nodo y disponemos los punteros izq y der a null, guardamos la informacin
que llega al mtodo en el nodo.
Si el rbol est vaco, apuntamos raz al nodo creado; en caso de no estar vaco,
dentro de una estructura repetitiva vamos comparando info con la informacin del nodo,
si info es mayor a la del nodo descendemos por el subrbol derecho en caso contrario
descendemos por el subrbol izquierdo.
Cuando se encuentra un subrbol vaco insertar el nodo en dicho subrbol. Para esto
llevamos un puntero anterior dentro del while.
private void ImprimirPre (Nodo reco)
{
if (reco != null)
{
Console.Write(reco.info + " ");
ImprimirPre (reco.izq);
ImprimirPre (reco.der);
}
}
public void ImprimirPre ()
{
ImprimirPre (raiz);
Console.WriteLine();
}
El mtodo ImprimirPre(), es decir el no recursivo se encarga de llamar al mtodo
recursivo pasando la direccin del nodo raiz.
El mtodo recursivo void ImprimirPre (Nodo reco) lo primero que verifica con un if si
reco est apuntando a un nodo (esto es verdad si reco es distinto a null), en caso
afirmativo ingresa al bloque del if y realiza:
- Visitar la raiz.
- Recorrer el subrbol izquierdo en pre-orden.
- Recorrer el subrbol derecho en pre-orden.
La visita en este caso es la impresin de la informacin del nodo y los recorridos son
las llamadas recursivas pasando las direcciones de los subrboles izquierdo y derecho.
Los algoritmos de los recorridos en entreorden y postorden son similares. La diferencia
es que la visita la realizamos entre las llamadas recursivas en el recorrido en entre
orden:
private void ImprimirEntre (Nodo reco)
{
if (reco != null)
{
ImprimirEntre (reco.izq);
Console.Write(reco.info + " ");
ImprimirEntre (reco.der);
}
}
y por ltimo en el recorrido en postorden la visita la realizamos luego de las dos
llamadas recursivas:
private void ImprimirPost (Nodo reco)
{
if (reco != null)
{
ImprimirPost (reco.izq);
ImprimirPost (reco.der);
Console.Write(reco.info + " ");
}
}
Problema 2:
Confeccionar una clase que permita insertar un entero en un rbol binario ordenado
verificando que no se encuentre previamente dicho nmero.
Desarrollar los siguientes mtodos:
1 - Retornar la cantidad de nodos del rbol.
2 - Retornar la cantidad de nodos hoja del rbol.
3 - Imprimir en entre orden.
4 - Imprimir en entre orden junto al nivel donde se encuentra dicho nodo.
5 - Retornar la altura del rbol.
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ArbolBinarioOrdenado2
{
public class ArbolBinarioOrdenado {
class Nodo
{
public int info;
public Nodo izq, der;
}
private Nodo raiz;
private int cant;
private int altura;
public ArbolBinarioOrdenado()
{
raiz=null;
}
public void Insertar (int info)
{
if (!Existe(info))
{
Nodo nuevo;
nuevo = new Nodo ();
nuevo.info = info;
nuevo.izq = null;
nuevo.der = null;
if (raiz == null)
raiz = nuevo;
else
{
Nodo anterior = null, reco;
reco = raiz;
}
}
public void ImprimirEntre ()
{
ImprimirEntre (raiz);
Console.WriteLine();
}
private void Cantidad(Nodo reco)
{
if (reco!=null)
{
cant++;
Cantidad(reco.izq);
Cantidad(reco.der);
}
}
public int Cantidad()
{
cant=0;
Cantidad(raiz);
return cant;
}
private void CantidadNodosHoja(Nodo reco)
{
if (reco!=null)
{
if (reco.izq==null && reco.der==null)
cant++;
CantidadNodosHoja(reco.izq);
CantidadNodosHoja(reco.der);
}
}
public int CantidadNodosHoja()
{
cant=0;
CantidadNodosHoja(raiz);
return cant;
}
private void ImprimirEntreConNivel (Nodo
reco,int nivel)
{
if (reco != null)
{
ImprimirEntreConNivel
(reco.izq,nivel+1);
Console.Write(reco.info + "
("+nivel+") - ");
ImprimirEntreConNivel
(reco.der,nivel+1);
}
}
public void ImprimirEntreConNivel ()
{
ImprimirEntreConNivel (raiz,1);
Console.WriteLine();
}
private void RetornarAltura (Nodo reco,int
nivel)
{
if (reco != null)
{
RetornarAltura (reco.izq,nivel+1);
if (nivel>altura)
altura=nivel;
RetornarAltura (reco.der,nivel+1);
}
}
public
int RetornarAltura ()
{
altura=0;
RetornarAltura (raiz,1);
return altura;
}
public void MayorValorl()
{
if (raiz!=null)
{
Nodo reco=raiz;
while (reco.der!=null)
reco=reco.der;
Console.WriteLine("Mayor valor del
rbol:"+reco.info);
}
}
public void BorrarMenor()
{
if (raiz!=null)
{
if (raiz.izq==null)
raiz=raiz.der;
else
{
Nodo atras=raiz;
Nodo reco=raiz.izq;
while (reco.izq!=null)
{
atras=reco;
reco=reco.izq;
}
atras.izq=reco.der;
}
}
}
static void Main(string[] args)
{
ArbolBinarioOrdenado abo = new
ArbolBinarioOrdenado ();
abo.Insertar (100);
abo.Insertar (50);
abo.Insertar (25);
abo.Insertar (75);
abo.Insertar (150);
Console.WriteLine ("Impresion entreorden:
");
abo.ImprimirEntre ();
Console.WriteLine("Cantidad de nodos del
rbol:"+abo.Cantidad());
Console.WriteLine("Cantidad de nodos
hoja:"+abo.CantidadNodosHoja());
Console.WriteLine("Impresion en entre
orden junto al nivel del nodo.");
abo.ImprimirEntreConNivel();
Console.Write ("Artura del arbol:");
Console.WriteLine(abo.RetornarAltura());
abo.MayorValorl();
abo.BorrarMenor();
Console.WriteLine("Luego de borrar el
menor:");
abo.ImprimirEntre ();
Console.ReadKey();
}
}
}
Para verificar si existe un elemento de informacin en el rbol disponemos un puntero
reco en el nodo apuntado por raiz. Dentro de un while verificamos si la informacin del
parmetro coincide con la informacin del nodo apuntado por reco, en caso afirmativo
salimos del mtodo retornando true, en caso contrario si la informacin a buscar es
mayor a la del nodo procedemos a avanzar reco con la direccin del subrbol derecho:
public bool Existe(int info)
{
Nodo reco=raiz;
while (reco!=null)
{
if (info==reco.info)
return true;
else
if (info>reco.info)
reco=reco.der;
else
reco=reco.izq;
}
return false;
}
Para retornar la cantidad de nodos del rbol procedemos a inicializar un atributo de la
clase llamado cant con cero. Llamamos al mtodo recursivo y en cada visita al nodo
incrementamos el atributo cant en uno:
private void Cantidad(Nodo reco)
{
if (reco!=null)
{
cant++;
Cantidad(reco.izq);
Cantidad(reco.der);
}
}
public int Cantidad()
{
cant=0;
Cantidad(raiz);
return cant;
}
Para imprimir todos los nodos en entre orden junto al nivel donde se encuentra
planteamos un mtodo recursivo que llegue la referencia del nodo a imprimir junto al
nivel de dicho nodo. Desde el mtodo no recursivo pasamos la referencia a raiz y un
uno (ya que raiz se encuentra en el primer nivel)
Cada vez que descendemos un nivel le pasamos la referencia del subrbol respectivo
junto al nivel que se encuentra dicho nodo:
private void ImprimirEntreConNivel (Nodo reco,int nivel)
{
if (reco != null)
{
ImprimirEntreConNivel (reco.izq,nivel+1);
Console.Write(reco.info + " ("+nivel+") - ");
ImprimirEntreConNivel (reco.der,nivel+1);
}
}
public void ImprimirEntreConNivel ()
{
ImprimirEntreConNivel (raiz,1);
Console.WriteLine();
}
Para obtener la altura del rbol procedemos en el mtodo no recursivo a inicializar el
atributo altura con el valor cero. Luego llamamos al mtodo recursivo con la referencia
a raiz que se encuentra en el nivel uno. Cada vez que visitamos un nodo procedemos a
verificar si el parmetro nivel supera al atributo altura, en dicho caso actualizamos el
atributo altura con dicho nivel.
private void RetornarAltura (Nodo reco,int nivel)
{
if (reco != null)
{
RetornarAltura (reco.izq,nivel+1);
if (nivel>altura)
altura=nivel;
RetornarAltura (reco.der,nivel+1);
}
}
public int RetornarAltura ()
{
altura=0;
RetornarAltura (raiz,1);
return altura;
}
Para imprimir el mayor valor del rbol debemos recorrer siempre por derecha hasta
encontrar un nodo que almacene null en der:
public void MayorValorl()
{
if (raiz!=null)
{
Nodo reco=raiz;
while (reco.der!=null)
reco=reco.der;
Console.WriteLine("Mayor
valor
del
rbol:"+reco.info);
}
}
Para borrar el menor valor del rbol lo primero que comprobamos es si el subrbol
izquierdo es nulo luego el menor del rbol es el nodo apuntado por raiz. Luego si el
subrbol izquierdo no est vaco procedemos a descender siempre por la izquierda
llevando un puntero en el nodo anterior. Cuando llegamos al nodo que debemos borrar
procedemos a enlazar el puntero izq del nodo que se encuentra en el nivel anterior con
la referencia del subrbol derecho del nodo a borrar:
public void BorrarMenor()
{
if (raiz!=null)
{
if (raiz.izq==null)
raiz=raiz.der;
else
{
Nodo atras=raiz;
Nodo reco=raiz.izq;
while (reco.izq!=null)
{
atras=reco;
reco=reco.izq;
}
atras.izq=reco.der;
}
}
}
Tipos enteros
Segn el valor entero mximo a almacenar podemos elegir entre: int (2147483,648,
2147483647) (es el que normalmente hemos elegido hasta este momento cada vez
que necesitamos almacenar un valor entero), byte (podemos almacenar un valor entre
0 y 255), sbyte (-128 y 127), short (-32768, 32767), ushort (0, 65535), uint (0,
4294967295), long (9223372036854775808, 9223372036854775807) y ulong (0,
18446744073709551615)
Problema 1:
Confeccionar un programa que defina variables enteras una por cada tipo. Mostrar por
pantalla el valor almacenado en cada variable
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace TiposDatosPrimitivos1
{
class Program
{
static void Main(string[] args)
{
byte v1 = 200;
Console.WriteLine("Valor almacenado
variable de tipo byte:" + v1);
sbyte v2=-100;
Console.WriteLine("Valor almacenado
variable de tipo sbyte:" + v2);
short v3 = 30000;
Console.WriteLine("Valor almacenado
variable de tipo short:" + v3);
ushort v4 = 60000;
Console.WriteLine("Valor almacenado
variable de tipo ushort:" + v4);
int v5 = -2000000000;
Console.WriteLine("Valor almacenado
variable de tipo int:" + v5);
uint v6 = 2000000000;
Console.WriteLine("Valor almacenado
variable de tipo uint:" + v6);
long v7 = -1000000000000000000;
Console.WriteLine("Valor almacenado
variable de tipo long:" + v7);
ulong v8 = 1000000000000000000;
Console.WriteLine("Valor almacenado
variable de tipo ulong:" + v8);
Console.ReadKey();
}
}
}
en la
en la
en la
en la
en la
en la
en la
en la
Problema 2:
Mostrar el valor mximo y mnimo que puede almacenar cada tipo de dato entero en
C#.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace TiposDatosPrimitivos2
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Valor mximo
para tipo de dato byte.");
Console.WriteLine("Mnimo:" +
byte.MinValue);
Console.WriteLine("Mximo:" +
byte.MaxValue);
Console.WriteLine("Valor mximo
para tipo de dato sbyte.");
Console.WriteLine("Mnimo:" +
sbyte.MinValue);
Console.WriteLine("Mximo:" +
sbyte.MaxValue);
Console.WriteLine("Valor mnimo
para tipo de dato short.");
Console.WriteLine("Mnimo:" +
short.MinValue);
Console.WriteLine("Mximo:" +
short.MaxValue);
Console.WriteLine("Valor mnimo
para tipo de dato ushort.");
Console.WriteLine("Mnimo:" +
ushort.MinValue);
Console.WriteLine("Mximo:" +
ushort.MaxValue);
Console.WriteLine("Valor mnimo
para tipo de dato int.");
y mnimo
y mnimo
y mximo
y mximo
y mximo
Console.WriteLine("Mnimo:" +
int.MinValue);
Console.WriteLine("Mximo:" +
int.MaxValue);
Console.WriteLine("Valor mnimo y mximo
para tipo de dato uint.");
Console.WriteLine("Mnimo:" +
uint.MinValue);
Console.WriteLine("Mximo:" +
uint.MaxValue);
Console.WriteLine("Valor mnimo y mximo
para tipo de dato long.");
Console.WriteLine("Mnimo:" +
long.MinValue);
Console.WriteLine("Mximo:" +
long.MaxValue);
Console.WriteLine("Valor mnimo y mximo
para tipo de dato ulong.");
Console.WriteLine("Mnimo:" +
ulong.MinValue);
Console.WriteLine("Mximo:" +
ulong.MaxValue);
Console.ReadKey();
}
}
}
Los tipos de datos primitivos tienen asociados clases con una serie de propiedades y
mtodos. Las propiedades MinValue y MaxValue nos permiten acceder a los valores
mnimos y mximos que pueden almacenar cada tipo de dato.
Tipos reales
Podemos almacenar la parte entera y la parte fraccionaria. Disponemos tres tipos de
datos reales: float, double y decimal.
Problema 3:
Mostrar el valor mximo y mnimo que puede almacenar cada tipo de dato real en C#.
Programa:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace TiposDatosPrimitivos3
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Valor mnimo y mximo
para tipo de dato float.");
Console.WriteLine("Mnimo:" +
float.MinValue);
Console.WriteLine("Mximo:" +
float.MaxValue);
Console.WriteLine("Valor mnimo y mximo
para tipo de dato double.");
Console.WriteLine("Mnimo:" +
double.MinValue);
Console.WriteLine("Mximo:" +
double.MaxValue);
Console.WriteLine("Valor mnimo y mximo
para tipo de dato decimal.");
Console.WriteLine("Mnimo:" +
decimal.MinValue);
Console.WriteLine("Mximo:" +
decimal.MaxValue);
Console.ReadKey();
}
}
}
El tipo de dato decimal es el que ms se adecua para almacenar datos monetarios
(tiene una precisin de 28 dgitos decimales)
Tipo char
El tipo de dato primitivo char puede almacenar un caracter Unicode.
char letra='A';
Tipo lgico
Puede almacenar el valor true o false.
bool encontrado=false;
Problema 4:
Mostrar cuantos bytes de memoria requieren cada tipo de dato primitivo en C# (utilizar
el operador sizeof)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace TiposDatosPrimitivos4
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Bytes reservados
el tipo byte:" + sizeof(byte));
Console.WriteLine("Bytes reservados
el tipo sbyte:" + sizeof(sbyte));
Console.WriteLine("Bytes reservados
el tipo short:" + sizeof(short));
Console.WriteLine("Bytes reservados
el tipo ushort:" + sizeof(ushort));
Console.WriteLine("Bytes reservados
el tipo int:" + sizeof(int));
Console.WriteLine("Bytes reservados
el tipo uint:" + sizeof(uint));
Console.WriteLine("Bytes reservados
el tipo long:" + sizeof(long));
Console.WriteLine("Bytes reservados
el tipo ulong:" + sizeof(ulong));
Console.WriteLine("Bytes reservados
el tipo float:" + sizeof(float));
Console.WriteLine("Bytes reservados
el tipo double:" + sizeof(double));
Console.WriteLine("Bytes reservados
el tipo decimal:" + sizeof(decimal));
para
para
para
para
para
para
para
para
para
para
para
C# nos permite mediante la palabra clave var definir e inicializar una variable y que
el compilador se encargue de definir su tipo teniendo en cuenta el valor que le
asignamos:
var x=10;
Problema 1:
Confeccionar un programa que defina variables con tipo de dato implcitos para
almacenar un entero, un real, un caracter y un valor lgico. Imprimir sus valores.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace DatosImplicitos1
{
class Program
{
static void Main(string[] args)
{
var edad = 44;
var distancia = 7.55;
var continua = true;
var tecla = 'A';
Console.WriteLine(edad);
Console.WriteLine(distancia);
Console.WriteLine(continua);
Console.WriteLine(tecla);
Console.ReadKey();
}
}
}
Problema propuesto
1. Imprimir los valores de 1 al 1000 utilizando un for y definiendo una variable
implcita
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace DatosImplicitos2
{
class Program
{
static void Main(string[] args)
{
for (var x = 1; x <= 1000; x++)
{
Console.Write(x + "-");
}
Console.ReadKey();
}
}
}
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PalabraClaveThis1
{
class Persona
{
private string nombre;
private int edad;
public Persona(string nom,int ed)
{
this.nombre = nom;
this.edad = ed;
this.Imprimir();
}
public void Imprimir()
{
Console.WriteLine("Nombre:" +
this.nombre);
Console.WriteLine("Edad:" + this.edad);
Console.ReadKey();
}
static void Main(string[] args)
{
Persona persona1 = new Persona("Juan
Carlos",30);
}
}
}
Esto significa que this almacena una referencia al objeto actual. Es comn no disponer
esta palabra clave antecediendola a cada atributo o llamada de mtodo:
this.nombre = nom;
this.edad = ed;
this.Imprimir();
Es decir lo ms comn es codificar con la sintaxis:
nombre = nom;
edad = ed;
Imprimir();
Pero hay caso donde debemos anteceder esta palabra clave como por ejemplo en los
caso que los parmetros de un mtodo coincidan con el mismo nombre que tienen
atributos de la clase:
public Persona(string nombre,int edad)
{
this.nombre = nombre;
this.edad = edad;
Imprimir();
}
Problema 1:
Almacenar los sueldos de 5 operarios en un vector, imprimir los elementos recorriendo
el vector con la estructura repetitiva foreach.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Estructuraforeach1
{
class SueldoEmpleados
{
private int[] sueldos;
public void Cargar()
{
sueldos = new int[5];
for (int f = 0; f < 5; f++)
{
Console.Write("Ingrese valor de la
componente:");
String linea;
linea = Console.ReadLine();
sueldos[f] = int.Parse(linea);
}
}
public void Imprimir()
{
foreach (int s in sueldos)
{
Console.WriteLine(s);
}
Console.ReadKey();
}
static void Main(string[] args)
{
SueldoEmpleados pv = new
SueldoEmpleados();
pv.Cargar();
pv.Imprimir();
}
}
}
El funcionamiento del foreach:
foreach (int s in sueldos)
{
Console.WriteLine(s);
}
La variable s almacena la primera vez el primer elemento del vector sueldos,
seguidamente se ejecuta el bloque del foreach (en este caso imprimimos el contenido
de
la
variable
s)
Es decir que s almacena en cada vuelta del foreach un elemento del vector.
Problema propuesto
1. Crear un vector de n elementos de tipo entero (n se ingresa por teclado) Mostrar
cuantos elementos son superiores a 100 (emplear el foreach para recorrer el vector)
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Estructuraforeach2
{
class Mayores100
{
private int[] vec;
public void Cargar()
{
Console.Write("Cantidad de elementos:");
int n = int.Parse(Console.ReadLine());
vec = new int[n];
for (int f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese valor de la
componente:");
String linea;
linea = Console.ReadLine();
vec[f] = int.Parse(linea);
}
}
Luego de la palabra clave switch entre parntesis indicamos una variable, luego con
una serie de case verificamos si dicha variable almacena un valor igual a [valor1,
valor2, valor3 etc.] en el caso de ser igual se ejecutan las instrucciones contenidas
en dicho case.
Si todos los case son falsos, luego se ejecutan las instrucciones contenidas
despus de la plabra default.
Problema 1:
Ingresar un valor entero entre 1 y 5. Luego mostrar en castellano el valor ingresado.
Si se ingresa un valor fuera de dicho rango mostrar un mensaje indicando tal
situacin
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Estructuraswitch1
{
class Program
{
static void Main(string[] args)
{
Console.Write("Ingrese un valor entre 1
y 5:");
int valor =
int.Parse(Console.ReadLine());
switch (valor)
{
case 1: Console.Write("uno");
break;
case 2: Console.Write("dos");
break;
case 3: Console.Write("tres");
break;
case 4: Console.Write("cuatro");
break;
case 5: Console.Write("cinco");
break;
default:
Console.Write("Se ingreso
un valor fuera de rango");
break;
}
Console.ReadKey();
}
}
}
Es obligatorio que est entre parntesis la variable luego de la palabra clave switch.
Luego de cada case debemos indicar el valor con el que se comparar la variable
(siempre debe ser un valor constante y no podemos disponer una variable luego de
la palabra case.
Es necesario la palabra break luego de cada bloque de instrucciones por cada case.
Problema 2:
Ingresar un nmero entre uno y cinco en castellano. Luego mostrar en formato
numrico. Si se ingresa un valor fuera de dicho rango mostrar un mensaje indicando
tal situacin
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Estructuraswitch2
{
class Program
{
static void Main(string[] args)
{
Console.Write("Ingrese un nmero en
castellano entre uno y cinco:");
string nro = Console.ReadLine();
switch (nro)
{
case "uno": Console.Write(1);
break;
case "dos": Console.Write(2);
break;
case "tres": Console.Write(3);
break;
case "cuatro": Console.Write(4);
break;
case "cinco": Console.Write(5);
break;
default: Console.Write("Debe
ingresar un valor entre uno y cinco");
break;
}
Console.ReadKey();
}
}
}
Esto quiere decir que podemos utilizar en el switch variables string para ser
comparadas.
Problema 1:
Implementar un mtodo que reciba dos enteros y luego imprima de uno en uno desde
el valor menor hasta el valor mayor.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosValor1
{
class Program
{
public void MostrarRango(int menor, int
mayor)
{
for (var x = menor; x <= mayor; x++)
{
Console.Write(x + " ");
}
}
static void Main(string[] args)
{
Program p = new Program();
p.MostrarRango(1, 25);
Console.ReadKey();
}
}
}
Como podemos ver los parmetros se separan por coma y son utilizados en el mtodo
(en este mtodo los dos parmetros por valor se llaman menor y mayor):
public void MostrarRango(int menor, int mayor)
Dentro del mtodo se utilizan los parmetros cual si fueran variables locales:
for (var x = menor; x <= mayor; x++)
{
Console.Write(x + " ");
}
Problema 2:
Confeccionar un mtodo que reciba como parmetros tres valores enteros y retorne el
mayor de los mismos.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosValor2
{
class Program
{
public int Mayor(int v1, int v2, int v3)
{
if (v1 >= v2 && v1 >= v3)
{
return v1;
}
else
{
if (v2 >= v3)
{
return v2;
}
else
{
return v3;
}
}
}
static void Main(string[] args)
{
Program p = new Program();
Console.Write("Ingrese primer valor:");
int x1 = int.Parse(Console.ReadLine());
Console.Write("Ingrese segundo valor:");
int x2 = int.Parse(Console.ReadLine());
Console.Write("Ingrese tercer valor:");
int x3 = int.Parse(Console.ReadLine());
Console.Write("El mayor valor de los tres
es:" + p.Mayor(x1, x2, x3));
Console.ReadKey();
}
}
}
El mtodo Mayor recibe tres parmetros y retorna un entero. Se inicializa con public ya
que lo llamamos desde donde definimos un objeto desde la Main:
Problema propuesto
1. Confeccionar un mtodo que reciba un entero entre 1 y 10 y retorne el valor en
castellano.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosValor3
{
class Program
{
public string RetornarCastellano(int x)
{
string valor;
switch (x)
{
case 1: valor = "uno";
break;
case 2: valor = "dos";
break;
case 3: valor = "tres";
break;
case 4: valor = "cuatro";
break;
case 5: valor = "cinco";
break;
case 6: valor = "seis";
break;
case 7: valor = "siete";
break;
case 8: valor = "ocho";
break;
case 9: valor = "nueve";
break;
Problema 1:
Implementar un mtodo que se le enven dos variables y nos devuelvan sus contenidos
intercambiados.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosReferencia1
{
class Program
{
Problema propuesto
1. Confeccionar un mtodo que reciba por referencia tres enteros y nos los retorne en
forma ordenada de menor a mayor.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosReferencia2
{
class Program
{
public void Ordenados(ref int v1, ref int v2, ref int
v3)
{
int menor;
int intermedio;
int mayor;
if (v1 <= v2 & v1 <= v3)
{
menor = v1;
if (v2 < v3)
{
intermedio = v2;
mayor = v3;
}
else
{
intermedio = v3;
mayor = v2;
}
}
else
{
if (v2 <= v3)
{
menor = v2;
if (v1 < v3)
{
intermedio = v1;
mayor = v3;
}
else
{
intermedio = v3;
mayor = v1;
}
}
else
{
menor = v3;
if (v1 < v2)
{
intermedio = v1;
mayor = v2;
}
else
{
intermedio = v2;
mayor = v1;
}
}
}
v1 = menor;
v2 = intermedio;
v3 = mayor;
}
static void Main(string[] args)
{
Program p = new Program();
Console.Write("Ingrese primer valor:");
int x1=int.Parse(Console.ReadLine());
Console.Write("Ingrese segundo valor:");
int x2 = int.Parse(Console.ReadLine());
Console.Write("Ingrese primer valor:");
int x3 = int.Parse(Console.ReadLine());
p.Ordenados(ref x1, ref x2, ref x3);
Console.WriteLine("Los valores ordenados de menor a
mayor:");
Console.WriteLine(x1 + " " + x2 + " " + x3);
Console.ReadKey();
}
}
}
Problema 1:
Implementar un programa que permita crear, cargar y obtener el menor y mayor valor
de un vector. La obtencin del mayor y menor hacerlo en un nico mtodo que retorne
dichos dos valores.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosReferencia3
{
class Program
{
private int[] vec;
public Program()
{
Console.Write("Tamao del vector:");
int tam = int.Parse(Console.ReadLine());
vec = new int[tam];
}
public void Cargar()
{
for (var f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese elemento:");
vec[f] =
int.Parse(Console.ReadLine());
}
}
{
may=vec[0];
men=vec[0];
for (var f = 1; f < vec.Length; f++)
{
if (vec[f] > may)
{
may = vec[f];
}
else
{
if (vec[f] < men)
{
men = vec[f];
}
}
}
}
Lo mismo cuando llamamos al mtodo debemos anteceder las variables que le
pasamos con la palabra clave out:
int ma, me;
p.MayorMenor(out ma, out me);
Como podemos ver las variables ma y me no tienen un valor previo a la llamada al
mtodo MayorMenor.
Problema propuesto
1. Confeccionar un mtodo que me retorne dos valores aleatorios comprendidos entre 1 y
100 mediante parmetros por referencia.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosReferencia4
{
class Program
{
public void DosValoresAleatorios(out int v1, out int v2)
{
Random r = new Random();
v1 = r.Next(1, 101);
v2 = r.Next(1, 101);
}
static void Main(string[] args)
{
int ale1, ale2;
Program p = new Program();
p.DosValoresAleatorios(out ale1, out ale2);
Console.WriteLine("Primer valor aleatorio:" + ale1);
Console.WriteLine("Segundo valor aleatorio:" +
ale2);
Console.ReadKey();
}
}
}
Problema 1:
Implementar un mtodo que le enve una cantidad n de enteros y me retorne la
suma de los mismos.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosVariables1
{
class Program
{
public int Sumar(params int[] p)
{
int su = 0;
for (var f = 0; f < p.Length; f++)
{
su = su + p[f];
}
return su;
}
static void Main(string[] args)
{
Program p = new Program();
Console.Write("La suma de 3,4,5 es ");
Console.WriteLine(p.Sumar(3,4,5));
Console.ReadKey();
}
}
}
Como podemos ver le antecedemos al nombre del vector la palabra clave params:
public int Sumar(params int[] p) { int su = 0; for (var f = 0; f < p.Length; f++) { su = su
+ p[f]; } return su; }
La diferencia fundamental es que desde donde llamamos al mtodo no le pasamos
un vector de enteros, sino una lista de parmetros enteros:
Console.WriteLine(p.Sumar(3,4,5));
Un mtodo solo puede tener un solo parmetro de este tipo y debe ser siempre el
ltimo, por ejemplo:
public int Sueldos(string nombre,params float[] su)
Problema propuesto
1. Confeccionar un mtodo que reciba un string con la cadena "suma" o
"producto" y seguidamente una lista de enteros. El mtodo debe retornar la
suma o producto de todos los valores enviados.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosVariables2
{
class Program
{
public int Operar(string operacion, params int[] v)
{
if (operacion == "suma")
{
int suma = 0;
for (var f = 0; f < v.Length; f++)
{
suma = suma + v[f];
}
return suma;
}
if (operacion == "producto")
{
int producto = 1;
for (var f = 0; f < v.Length; f++)
{
producto=producto * v[f];
}
return producto;
}
return int.MaxValue;
}
static void Main(string[] args)
{
Program p = new Program();
Console.Write("El producto de 2*3*4 es ");
Console.WriteLine(p.Operar("producto", 2, 3, 4));
Console.Write("La suma de 5+10 es ");
Console.WriteLine(p.Operar("suma", 5, 10));
Console.ReadKey();
}
}
}
Los parmetros opcionales deben ser siempre los ltimos que indiquemos. El
parmetro mensaje no es opcional por lo que si o si debe especificarse.
Problema 1:
Implementar un mtodo que muestre un mensaje en la pantalla con dos parmetros
opciones que indiquen la columna y la fila donde imprimir.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosOpcionales1
{
class Program
{
public void Imprimir(string mensaje, int
col = 1, int fil = 1)
{
Console.SetCursorPosition(col, fil);
Console.Write(mensaje);
}
static void Main(string[] args)
{
Program ob1 = new Program();
ob1.Imprimir("Hola");
ob1.Imprimir("Hola", 40);
ob1.Imprimir("Hola", 40, 12);
Console.ReadKey();
}
}
}
Problema propuesto
1. Confeccionar un mtodo que muestre los primeros 10 nmeros pares. En
caso que le pasemos un parmetro opcional mostrar tantos pares como
indica el parmetro.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosOpcionales2
{
class Program
{
public void Pares(int cant = 10)
{
int par = 2;
for (var x = 1; x <= cant; x++)
{
Console.Write(par + "-");
par = par + 2;
}
}
static void Main(string[] args)
{
Program ob1 = new Program();
ob1.Pares();
Console.WriteLine();
Console.WriteLine();
ob1.Pares(20);
Console.ReadKey();
}
}
}
Problema 1:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ParametrosNombre1
{
class Program
{
public void Imprimir(string mensaje, int
columna, int fila)
{
Console.SetCursorPosition(columna, fila);
Console.WriteLine(mensaje);
}
static void Main(string[] args)
{
Program ob1 = new Program();
ob1.Imprimir(fila: 12, columna: 40,
mensaje: "Hola Mundo");
ob1.Imprimir(mensaje: "Fin", fila: 23,
columna: 5);
Console.ReadKey();
}
}
}
Como podemos observar previo al dato a enviar le antecedemos el nombre del
parmetro y luego de dos puntos el dato a enviar:
ob1.Imprimir(fila: 12, columna: 40, mensaje: "Hola
Mundo");
ob1.Imprimir(mensaje: "Fin", fila: 23, columna: 5);
Problema 1:
Implementar dos mtodos que sumen dos enteros en el primer caso y que
concatenen dos string en el segundo.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaParametros1
{
class Program
{
public int Sumar(int x1, int x2)
{
int s = x1 + x2;
return s;
}
public string Sumar(string s1, string s2)
{
string s = s1 + s2;
return s;
}
static void Main(string[] args)
{
Cuando llamamos a los mtodos el compilador sabe con cual enlazarlos segn el
tipo de datos enviados.
Si le enviamos dos enteros se llama el primer mtodo:
Console.WriteLine("La suma de 5+10 es:" + p.Sumar(5, 10));
Problema 2:
Plantear una clase llamada Ventana que defina cuatro mtodos sobrecargados que
muestren un mensaje en la consola.
El primero lo muestrar donde se encuentra actualmente el cursor.
El segundo lo muestra en una determinada columna y fila.
El tercero lo muestra en una determinada columna,fila y con un color de letra.
Y por ltimo similar al anterior ms un color de fondo.
Programa:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace SobrecargaParametros2
{
class Ventana
{
public void Mostrar(string mensaje)
{
Console.Write(mensaje);
}
public void Mostrar(string mensaje, int
columna,int fila)
{
Console.SetCursorPosition(columna,
fila);
Console.Write(mensaje);
}
public void Mostrar(string mensaje, int
columna, int fila,ConsoleColor colorletra)
{
Console.ForegroundColor = colorletra;
Mostrar(mensaje, columna, fila);
}
public void Mostrar(string mensaje, int
columna, int fila, ConsoleColor
colorletra,ConsoleColor colorfondo)
{
Console.BackgroundColor = colorfondo;
Mostrar(mensaje, columna, fila,
colorletra);
}
static void Main(string[] args)
{
Ventana v = new Ventana();
v.Mostrar("Hola Mundo");
v.Mostrar("Hola Mundo", 30, 10);
v.Mostrar("Hola Mundo", 30, 12,
ConsoleColor.Red);
v.Mostrar("Hola Mundo", 30, 14,
ConsoleColor.Red, ConsoleColor.Blue);
Console.ReadKey();
}
}
}
Como podemos observar hemos definido cuatro mtodos llamados Mostrar que
difieren
en
la
cantidad
de
parmetros.
El primero recibe un string y lo muestra en la consola:
public void Mostrar(string mensaje)
{
Console.Write(mensaje);
}
int
columna,
int
int
fila,
Problema propuesto
1. Plantear una clase que sobrecargue un mtodo que permita cargar por
referencia (out) distintos tipos de datos primitivos por teclado.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaParametros3
{
class EntradaTeclado
{
public void Leer(out int valor)
{
valor = int.Parse(Console.ReadLine());
}
public void Leer(out float valor)
{
valor = float.Parse(Console.ReadLine());
}
public void Leer(out char valor)
{
valor = char.Parse(Console.ReadLine());
}
public void Leer(out bool valor)
{
valor = bool.Parse(Console.ReadLine());
}
static void Main(string[] args)
{
EntradaTeclado et = new EntradaTeclado();
int x;
Console.Write("Ingrese un entero:");
et.Leer(out x);
Console.WriteLine("El valor ingresado es:" + x);
float f;
Problema 1:
Implementar una clase que represente un titulo en pantalla. Definir un constructor
que reciba el string del ttulo y otro constructor que reciba el string del ttulo y la
columna y fila donde mostrarlo.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaConstructor1
{
class Titulo
{
private string tit;
private int columna;
private int fila;
public Titulo(string t)
{
tit = t;
columna = 1;
fila = 1;
}
public Titulo(string t, int col, int fil)
{
tit = t;
columna = col;
fila = fil;
}
public void Imprimir()
{
Console.SetCursorPosition(columna,
fila);
Console.Write(tit);
}
static void Main(string[] args)
{
Titulo t1 = new Titulo("Hola Mundo");
t1.Imprimir();
Titulo t2 = new Titulo("Hola
Mundo",40,12);
t2.Imprimir();
Console.ReadKey();
}
}
}
Hemos planteado dos constructores, uno que recibe un string y otro que recibe un
string y dos enteros (los mismos inicializan atributos de la clase):
public Titulo(string t)
{
tit = t;
columna = 1;
fila = 1;
}
public Titulo(string t, int col, int fil)
{
tit = t;
columna = col;
fila = fil;
}
El segundo objeto que creamos se llama al constructor que tiene tres parmetros:
Titulo t2 = new Titulo("Hola Mundo",40,12);
t2.Imprimir();
Problema 1:
Implementar una clase llamada Operacion. Definir dos mtodos estticos que
permitan sumar y restar dos valores enteros.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace MetodosEstaticos1
{
class Operacion
{
public static int Sumar(int x1, int x2)
{
int s = x1+x2;
return s;
}
public static int Restar(int x1,int x2)
{
int r = x1 - x2;
return r;
}
}
class Program
{
static void Main(string[] args)
{
Console.Write("La suma de 2+4 es ");
Console.WriteLine(Operacion.Sumar(2,
4));
Console.Write("La resta de 6-2 es ");
Console.WriteLine(Operacion.Restar(6,
2));
Console.ReadKey();
}
}
}
Agregamos la palabra clave static antes de indicar el valor que retorna el mtodo:
public static int Sumar(int x1, int x2)
{
int s = x1+x2;
return s;
}
Problema propuesto
1. Plantear una clase llamada VectorEnteros que defina tres mtodos estticos.
El primero retorna el mayor elemento del vector, el segundo el menor
elemento y el tercero la suma de sus componentes.
SOLUCION
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace MetodosEstaticos2
{
class VectorEnteros
{
public static int Mayor(int[] vec)
{
int may = vec[0];
for (int x = 0; x < vec.Length; x++)
{
if (vec[x] > may)
{
may = vec[x];
}
}
return may;
}
public static int Menor(int[] vec)
{
int men = vec[0];
for (int x = 0; x < vec.Length; x++)
{
if (vec[x] < men)
{
men = vec[x];
}
}
return men;
}
public static int SumaElementos(int[] vec)
{
int suma = 0;
for (int x = 0; x < vec.Length; x++)
{
suma = suma + vec[x];
}
return suma;
}
public static void Imprimir(int[] vec)
{
Console.Write("Impresin del vector:");
for (int x = 0; x < vec.Length; x++)
{
Console.Write(vec[x] + " "); ;
}
Console.WriteLine();
}
}
class Program
{
static void Main(string[] args)
{
int[] v = { 5, 6, 20 };
VectorEnteros.Imprimir(v);
Console.WriteLine("El mayor elemento del vector es
:" + VectorEnteros.Mayor(v));
Console.WriteLine("El menor elemento del vector es
:" + VectorEnteros.Menor(v));
Console.Write("La suma de los elementos del vector
es :" + VectorEnteros.SumaElementos(v));
Console.ReadKey();
}
}
}
Problema 1:
Definir un atributo esttico que almacene la cantidad de objetos creados de dicha clase.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace AtributosEstaticos1
{
class Persona
{
private string nombre;
private int edad;
public static int cantidad;
public Persona(string nom,int ed)
{
cantidad++;
nombre = nom;
edad = ed;
}
public void Imprimir()
{
Console.WriteLine(nombre + "-" + edad);
}
}
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Valor del atributo
esttico cantidad:" + Persona.cantidad);
Persona per1 = new Persona("juan", 30);
per1.Imprimir();
Console.WriteLine("Valor del atributo
esttico cantidad:" + Persona.cantidad);
Persona per2 = new Persona("ana", 20);
per2.Imprimir();
Console.WriteLine("Valor del atributo
esttico cantidad:" + Persona.cantidad);
Persona per3 = new Persona("luis", 10);
per3.Imprimir();
Console.WriteLine("Valor del atributo
esttico cantidad:" + Persona.cantidad);
Console.ReadKey();
}
}
}
Un atributo esttico de tipo entero se inicializa en cero cuando lo definimos (lo
definimos de tipo public para poder acceder a su valor desde afuera de la clase):
public static int cantidad;
En el constructor de la clase incrementamos el atributo esttico en uno:
public Persona(string nom,int ed)
{
cantidad++;
nombre = nom;
edad = ed;
}
Desde fuera de la clase podemos acceder a dicho atributo mediante el nombre de la
clase sin tener que definir un objeto de la misma:
Console.WriteLine("Valor
del
atributo
esttico
cantidad:" + Persona.cantidad);
Luego de crear un objeto de la clase Persona se ejecuta el constructor de la clase
donde se incrementa en uno el atributo esttico cantidad:
Persona per1 = new Persona("juan", 30);
Si mostramos nuevamente el atributo cantidad veremos que su contenido es uno:
Console.WriteLine("Valor
del
atributo
esttico
cantidad:" + Persona.cantidad);
No importa cuantos objeto de la clase Persona se creen luego existe un solo atributo
cantidad:
Persona per2 = new Persona("ana", 20);
per2.Imprimir();
Console.WriteLine("Valor
del
atributo
esttico
cantidad:" + Persona.cantidad);
Persona per3 = new Persona("luis", 10);
per3.Imprimir();
Console.WriteLine("Valor
del
atributo
esttico
cantidad:" + Persona.cantidad);
Si queremos encapsular el atributo cantidad en la clase Persona luego podemos definir
una propiedad esttica.
Problema 2:
Definir una propiedad esttica para acceder a un atributo esttico que guarda la
cantidad de objetos creados de dicha clase.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace PropiedadesEstaticas1
{
class Persona
{
private string nombre;
per2.Imprimir();
Console.WriteLine("Valor del atributo
esttico cantidad:" + Persona.Cantidad);
Persona per3 = new Persona("luis", 10);
per3.Imprimir();
Console.WriteLine("Valor del atributo
esttico cantidad:" + Persona.Cantidad);
Console.ReadKey();
}
}
}
Como vemos ahora definimos el atributo esttico de tipo privado:
private static int cantidad;
Esto hace necesario implementar una propiedad esttica para acceder a su contenido:
public static int Cantidad
{
set
{
cantidad = value;
}
get
{
return cantidad;
}
}
Luego para acceder a su valor desde fuera debemos preguntar el valor de la propiedad
Cantidad ya que el atributo cantidad es privado:
Console.WriteLine("Valor
del
atributo
esttico
cantidad:" + Persona.Cantidad);
Si queremos pulir un poco ms este problema podemos eliminar la parte del set de la
propiedad Cantidad:
public static int Cantidad
{
get
{
return cantidad;
}
}
Esto hace que no podamos por error asignar a la propiedad Cantidad un valor (genera
un error en tiempo de compilacin, ya que se trata de una propiedad de solo lectura):
Persona.Cantidad = 71;
El incremento del atributo cantidad solo se hace en el constructor de la clase Persona
cada vez que creamos un objeto.
Problema 1:
Definir una clase esttica llamada Operaciones. Implementar cuatro mtodos que
permitan sumar,restar,multiplicar y dividir dos enteros.:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace ClaseEstatica1
{
static class Operaciones
{
public static int Sumar(int valor1, int
valor2)
{
return valor1 + valor2;
}
public static int Restar(int valor1, int
valor2)
{
return valor1 - valor2;
}
public static int Multiplicar(int valor1, int
valor2)
{
return valor1 * valor2;
}
public static int Dividir(int valor1, int
valor2)
{
return valor1 / valor2;
}
}
class Program
{
static void Main(string[] args)
{
Console.WriteLine("10+5 es "
Operaciones.Sumar(10, 5));
Console.WriteLine("10-5 es "
Operaciones.Restar(10, 5));
Console.WriteLine("10*5 es "
Operaciones.Multiplicar(10, 5));
Console.WriteLine("10/5 es "
Operaciones.Dividir(10, 5));
Console.ReadKey();
}
}
}
+
+
+
+
}
ERROR| Sumar: no se puede declarar miembros estticos en una clase esttica.
Tambin se genera un error si queremos crear un objeto de una clase esttica:
Operaciones op = new Operaciones();
ERROR| No se puede crear ninguna instancia de la clase Operaciones.
72.- Enumeraciones
Una enumeracin es un conjunto de constantes enteras que tienen asociado un
nombre para cada valor.
El objetivo fundamental de implementar una enumeracin es facilitar la legibilidad de un
programa.
Supongamos que necesitamos almacenar en un juego de cartas el tipo de carta actual
(oro, basto, copa o espada), podemos definir una variable entera y almacenar un 1 si
es oro, un 2 si es basto y as sucesivamente.
Luego mediante if podemos analizar el valor de esa variable y proceder de acuerdo al
valor existente.
Problema 1:
Definir un tipo de dato enumerado para cada tipo de carta de una baraja espaola.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Enumeracion1
{
class JuegoDeCartas
{
public enum TipoCarta { oro, basto, copa,
espada };
private TipoCarta cartaActual;
public void Imprimir()
{
cartaActual = TipoCarta.oro;
Console.WriteLine("El valor actual es:" +
cartaActual);
cartaActual = TipoCarta.espada;
Problema propuesto
1. Elaborar una calculadora para trabajar con valores enteros(utilizar objetos de la clase
Button y un objeto de la clase Label donde se muestra el valor ingresado) definir un tipo
de dato enumerado para las cuatro operaciones bsicas. Cuando se presione algunos
de los botones de operaciones almacenar en una memoria el valor ingresado y el tipo
de operacin pendiente en una variable del tipo de dato enumerado creado. Cuando se
presione el botn igual verificar el tipo de operacin pendiente y proceder a obtener el
resultado y mostrarlo en la Label.
SOLUCION
using
using
using
using
using
using
using
using
System;
System.Collections.Generic;
System.ComponentModel;
System.Data;
System.Drawing;
System.Linq;
System.Text;
System.Windows.Forms;
namespace CalculadoraEnumeracion
{
public partial class Form1 : Form
{
public enum TipoOperacion { ninguna ,suma, resta,
multiplicacion, division };
private TipoOperacion operacion=TipoOperacion.ninguna;
private int memoria;
public Form1()
{
InitializeComponent();
}
}
}
}
Problema 1:
Plantear una clase VectorEnteros que permita crear un vector de 5 elementos y
sobrecargue el operador +
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaOperadores1
{
class VectorEnteros
{
private int []vec;
public VectorEnteros()
{
vec = new int[5];
}
public void Cargar()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese componente:");
vec[f] =
int.Parse(Console.ReadLine());
}
}
public void Imprimir()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write(vec[f] + " ");
}
Console.WriteLine();
}
public static VectorEnteros operator
+(VectorEnteros v1, VectorEnteros v2)
{
VectorEnteros su = new VectorEnteros();
for (int f = 0; f < su.vec.Length; f++)
{
su.vec[f] = v1.vec[f] + v2.vec[f];
}
return su;
}
}
class Program
{
static void Main(string[] args)
{
VectorEnteros v1 = new VectorEnteros();
Console.WriteLine("Carga del primer
vector");
v1.Cargar();
VectorEnteros v2 = new VectorEnteros();
Console.WriteLine("Carga del segundo
vector");
v2.Cargar();
Console.WriteLine("Primer Vector");
v1.Imprimir();
Console.WriteLine("Segundo Vector");
v2.Imprimir();
VectorEnteros vt;
vt = v1 + v2;
Console.WriteLine("Vector Resultante");
vt.Imprimir();
Console.ReadKey();
}
}
}
La sintaxis para sobrecargar un operador binario es:
public static {valor que retorna} operator {operador}(tipoparametro nombre, tipo-parametro nombre)
En nuestro ejemplo el tipo de dato que retorna es un objeto de la clase VectorEnteros.
El operador que estamos sobrecargando es el "+" y entre parntesis indicamos los dos
parmetros que llegan que son objetos de la clase VectorEnteros:
public static VectorEnteros operator +(VectorEnteros v1,
VectorEnteros v2)
Dentro del mtodo creamos un objeto de la clase VectorEnteros:
VectorEnteros su = new VectorEnteros();
Luego mediante un for cargamos cada elemento del vector de enteros con los datos de
las componentes homlogas de los otros dos vectores:
for (int f = 0; f < su.vec.Length; f++)
{
su.vec[f] = v1.vec[f] + v2.vec[f];
}
Como estamos en la clase VectorEnteros podemos acceder a los atributos privados
vec.
Finalmente retornamos el objeto de la clase VectorEnteros que acabamos de crear:
return su;
El mtodo completo queda codificado entonces con la siguiente sintaxis:
public static VectorEnteros operator +(VectorEnteros v1,
VectorEnteros v2)
{
VectorEnteros su = new VectorEnteros();
for (int f = 0; f < su.vec.Length; f++)
{
su.vec[f] = v1.vec[f] + v2.vec[f];
}
return su;
}
Problema 2:
Plantear una clase VectorEnteros que permita crear un vector de 5 elementos y
sobrecargue el operador * de un objeto de la clase VectorEnteros con un valor de tipo
int (el resultado debe ser otro objeto de la clase VectorEnteros donde cada componente
se obtiene de multiplicar su valor por el valor entero)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaOperadores2
{
class VectorEnteros
{
private int[] vec;
public VectorEnteros()
{
vec = new int[5];
}
public void Cargar()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese componente:");
vec[f] =
int.Parse(Console.ReadLine());
}
}
public void Imprimir()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write(vec[f] + " ");
}
Console.WriteLine();
}
public static VectorEnteros operator
*(VectorEnteros v1, int valor)
{
VectorEnteros resu = new VectorEnteros();
for (int f = 0; f < resu.vec.Length; f++)
{
resu.vec[f] = v1.vec[f] * valor;
}
return resu;
}
}
class Program
{
static void Main(string[] args)
{
VectorEnteros v1 = new VectorEnteros();
Console.WriteLine("Carga del vector");
v1.Cargar();
VectorEnteros vr;
Console.WriteLine("Primer Vector");
v1.Imprimir();
vr = v1 * 10;
Console.WriteLine("Vector resultante");
vr.Imprimir();
Console.ReadKey();
}
}
}
Como vemos ahora estamos sobrecargando el operador "*". El mtodo tiene dos
parmetros uno de tipo VectorEnteros y otro de tipo int:
public static VectorEnteros operator *(VectorEnteros v1,
int valor)
{
VectorEnteros resu = new VectorEnteros();
for (int f = 0; f < resu.vec.Length; f++)
{
resu.vec[f] = v1.vec[f] * valor;
}
return resu;
}
No lo hemos hecho pero podramos tambin sobrecargar el operador "*" y recibir como
parmetro dos objetos de la clase VectorEnteros:
public static VectorEnteros operator *(VectorEnteros v1,
VectorEnteros v2)
{
VectorEnteros resu = new VectorEnteros();
for (int f = 0; f < resu.vec.Length; f++)
{
resu.vec[f] = v1.vec[f] * v2.vec[f];
}
return resu;
}
Operacin unaria
Los ejemplos anteriores mostraban la sobrecarga de operadores binarios (un operador
y dos operandos), un operador unario afecta solo un operado.
Problema 3:
Sobrecargar el operador ++ en la clase VectorEnteros (se debe incrementar en uno
cada elemento)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaOperadores3
{
class VectorEnteros
{
private int[] vec;
public VectorEnteros()
{
vec = new int[5];
}
public void Cargar()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese componente:");
vec[f] =
int.Parse(Console.ReadLine());
}
}
public void Imprimir()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write(vec[f] + " ");
}
Console.WriteLine();
}
public static VectorEnteros operator
++(VectorEnteros v)
{
VectorEnteros resu = new VectorEnteros();
for (int f = 0; f < v.vec.Length; f++)
{
resu.vec[f]=v.vec[f]+1;
}
return resu;
}
}
class Program
{
static void Main(string[] args)
{
VectorEnteros v1 = new VectorEnteros();
Console.WriteLine("Carga del vector");
v1.Cargar();
Console.WriteLine("Impresin del
vector");
v1.Imprimir();
v1++;
Console.WriteLine("Impresin del vector
luego del operador ++");
v1.Imprimir();
Console.ReadKey();
}
}
}
Cuando se sobrecarga un operador unario tenemos un solo parmetro:
public static VectorEnteros operator ++(VectorEnteros v)
{
VectorEnteros resu = new VectorEnteros();
for (int f = 0; f < v.vec.Length; f++)
{
resu.vec[f]=v.vec[f]+1;
}
return resu;
}
Para ejecutar el operador luego desde la Main:
VectorEnteros v1 = new VectorEnteros();
Console.WriteLine("Carga del vector");
v1.Cargar();
Console.WriteLine("Impresin del vector");
v1.Imprimir();
v1++;
==
!=
<
>
<=
>=
Problema 4:
Sobrecargar el operador == en la clase VectorEnteros (retornar true si los cinco enteros
son iguales)
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace SobrecargaOperadores4
{
class VectorEnteros
{
private int[] vec;
public VectorEnteros()
{
vec = new int[5];
}
public void Cargar()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write("Ingrese componente:");
vec[f] =
int.Parse(Console.ReadLine());
}
}
public void Imprimir()
{
for (int f = 0; f < vec.Length; f++)
{
Console.Write(vec[f] + " ");
}
Console.WriteLine();
}
public static bool operator ==(VectorEnteros
v1, VectorEnteros v2)
{
for (int f = 0; f < v1.vec.Length; f++)
{
if (v1.vec[f] != v2.vec[f])
return false;
}
return true;
}
public static bool operator !=(VectorEnteros
v1, VectorEnteros v2)
{
for (int f = 0; f < v1.vec.Length; f++)
{
if (v1.vec[f] == v2.vec[f])
return false;
}
return true;
}
}
class Program
{
static void Main(string[] args)
{
{
class A
{
private int []vec;
public A()
{
vec=new int[3];
}
public int this[int indice]
{
set
{
vec[indice] = value;
}
get
{
return vec[indice];
}
}
}
static void Main(string[] args)
{
A obj1 = new A();
obj1[0] = 7;
obj1[1] = 34;
obj1[2] = 45;
Console.WriteLine(obj1[0]);
Console.WriteLine(obj1[1]);
Console.WriteLine(obj1[2]);
Console.ReadKey();
}
}
}
Definimos y creamos un vector de enteros de 3 elementos:
private int []vec;
public A()
{
vec=new int[3];
}
Definimos un indizador con parmetro entero llamado indice(veremos ms adelante
que el parmetro puede ser de otro tipo o inclusive tener ms de uno) Utilizamos la
palabra this para indicar que es un indizador.
En la seccion del set se ejecuta cuando le asignamos un valor donde definimos un
objeto de dicha clase (obj1[0] = 7;) es cero lo recibe el parmetro indice y el 7 lo
almacena la palabra clave value. Por ltimo la seccin del get se ejecuta cuando lo
accedemos (Console.WriteLine(obj1[0]);
public int this[int indice]
{
set
{
vec[indice] = value;
}
get
{
return vec[indice];
}
}
Para crear un objeto de la clase A lo hacemos como ya conocemos:
A obj1 = new A();
Lo nuevo es cuando queremos utilizar el indizador para inicializar datos (ejecuta el set
del indizador):
obj1[0] = 7;
obj1[1] = 34;
obj1[2] = 45;
O cuando queremos acceder al indizador para consultas (ejecuta el get):
Console.WriteLine(obj1[0]);
Console.WriteLine(obj1[1]);
Console.WriteLine(obj1[2]);
Console.ReadKey();
Problema 1:
Confeccionar una clase llamada Cliente definir las propiedades Nombre y Dinero (en el
constructor
inicializar
dichas
propiedades)
Desarrollar otra clase llamada Banco donde debemos definir y crear un vector de tres
elementos
de
tipo
Cliente.
Implementar un indizador en la clase Banco que permita acceder a cada cliente por un
subndice entero.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Indizador2
{
class Cliente
{
private string nombre;
public string Nombre
{
set
{
nombre = value;
}
get
{
return nombre;
}
}
private int dinero;
public int Dinero
{
set
{
dinero = value;
}
get
{
return dinero;
}
}
public Cliente(string nom, int din)
{
Nombre = nom;
Dinero = din;
}
}
class Banco
{
private Cliente[] clientes;
public Banco()
{
clientes = new Cliente[3];
}
}
}
La clase Banco implementa el indizador:
public Cliente this[int indice]
{
set
{
clientes[indice] = value;
}
get
{
return clientes[indice];
}
}
Para ver las ventajas que presenta implementar un indizador en la clase Banco
podemos ver como se inicializan los tres clientes que tiene el banco:
Banco banco1 = new Banco();
Cliente cli1 = new Cliente("juan", 1000);
Cliente cli2 = new Cliente("ana", 2000);
Cliente cli3 = new Cliente("luis", 1500);
banco1[0] = cli1;
banco1[1] = cli2;
banco1[2] = cli3;
Como podemos ver le asignamos al objeto indicando un subndice la referencia del
objeto de la clase Cliente.
Para poder imprimir el nombre y dinero depositado que tiene cada cliente lo hacemos
accediendo al subndice y seguidamente la propiedad del cliente que necesitamos
mostrar:
Console.WriteLine("Datos de los clientes.");
Console.WriteLine(banco1[0].Nombre);
Console.WriteLine(banco1[0].Dinero);
Console.WriteLine();
Console.WriteLine(banco1[1].Nombre);
Console.WriteLine(banco1[1].Dinero);
Console.WriteLine();
Console.WriteLine(banco1[2].Nombre);
Console.WriteLine(banco1[2].Dinero);
Console.WriteLine();
{
valor que retorna segn indices
}
set
{
fijar el valor segn indices
}
}
Problema 2:
Implementar una clase llamada Tablero del juego de la Batalla Naval. Permitir mediante
un indizador de dos dimensiones acceder a las casillas del tablero.
Programa:
using
using
using
using
System;
System.Collections.Generic;
System.Linq;
System.Text;
namespace Indizador3
{
public enum DatoCasilla { agua, barco };
class Tablero
{
private DatoCasilla [,] mat;
public Tablero()
{
mat = new DatoCasilla[10, 10];
}
public void Graficar()
{
for (int f = 0; f < mat.GetLength(0);
f++)
{
for (int c = 0; c < mat.GetLength(1);
c++)
{
if (mat[f, c] ==
DatoCasilla.agua)
{
Console.Write("0");
}
if (mat[f, c] ==
DatoCasilla.barco)
{
Console.Write("-");
}
}
Console.WriteLine();
}
}
public DatoCasilla this[int fila, int
columna]
{
set
{
mat[fila, columna] = value;
}
get
{
return mat[fila, columna];
}
}
}
class Program
{
static void Main(string[] args)
{
Tablero tablero1 = new Tablero();
tablero1[0, 0] = DatoCasilla.barco;
tablero1[0, 1] = DatoCasilla.barco;
tablero1[0, 2] = DatoCasilla.barco;
tablero1[0, 9] = DatoCasilla.barco;
tablero1[1, 9] = DatoCasilla.barco;
tablero1[2, 9] = DatoCasilla.barco;
tablero1.Graficar();
Console.WriteLine();
if (tablero1[0, 0] == DatoCasilla.barco)
{
Console.WriteLine("Hay un barco en
esta casilla");
}
else
{
if (tablero1[0, 0] ==
DatoCasilla.agua)
{
Console.WriteLine("Agua");
}
}
Console.ReadKey();
}
}
}
Declaramos un tipo de dato enumerado con dos valores posibles:
public enum DatoCasilla { agua, barco };
Declaramos en la clase Tablero una matriz regular con componentes de tipo
DatoCasilla:
private DatoCasilla [,] mat;
En el constructor creamos la matriz de 10 filas por 10 columnas:
public Tablero()
{
mat = new DatoCasilla[10, 10];
}
Imprimimos el tablero, si en la componente hay "agua" mostramos un cero y si hay
"barco" mostramos un guin (cuando se cre la matriz en el constructor se inicializan
todas las componentes con el valor 0 que es "agua"):
public void Graficar()
{
for (int f = 0; f < mat.GetLength(0); f++)
{
for (int c = 0; c < mat.GetLength(1); c++)
{
if (mat[f, c] == DatoCasilla.agua)
{
Console.Write("0");
}
if (mat[f, c] == DatoCasilla.barco)
{
Console.Write("-");
}
}
Console.WriteLine();
}
}
Ahora veamos lo ms importante que es la definicin del indizador con dos subndices:
public DatoCasilla this[int fila, int columna]
{
set
{
mat[fila, columna] = value;
}
get
{
return mat[fila, columna];
}
}
En la otra clase creamos un objeto de la clase Tablero:
class Program
{
static void Main(string[] args)
{
Tablero tablero1 = new Tablero();
Seguidamente disponemos un barco en la primer fila de la matriz utilizando un
indizador (estas tres lneas acceden al set del indizador pasando los dos subndices y
el valor a almacenar):
tablero1[0, 0] = DatoCasilla.barco;
tablero1[0, 1] = DatoCasilla.barco;
tablero1[0, 2] = DatoCasilla.barco;
Un segundo barco lo ubicamos en la ltima columna:
tablero1[0, 9]
tablero1[1, 9]
tablero1[2, 9]
Para saber que hay en una casilla
(se ejecuta el get):
= DatoCasilla.barco;
= DatoCasilla.barco;
= DatoCasilla.barco;
cualquiera del tablero podemos utilizar el indizador
if (tablero1[0, 0] == DatoCasilla.barco)
{
Console.WriteLine("Hay
un
barco
casilla");
}
else
{
if (tablero1[0, 0] == DatoCasilla.agua)
{
Console.WriteLine("Agua");
}
}
ESTO ES TODO, OJALA LES GUSTE
SALUDOS
en
esta