Problema 1:
Confeccionar un programa que permita cargar los nombres de 5 alumnos y sus notas respectivas. Luego ordenar las mayor a menor. Imprimir las notas y los nombres de los alumnos.Programa:
using System; using System.Collections.; using System.Linq; using 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"); for(int f=0;f < nombres.Length;f++) { Console.Write("Ingese el nombre del alumno:"); nombres[f]=Console.ReadLine(); Console.Write("Ingrese la nota del alumno:"); string linea; linea = Console.ReadLine(); notas[f]=int.Parse(linea); } } public void Ordenar() { for (int k = 0; k < notas.Length; k++) { for (int f = 0; f < notas.Length - 1 - k; f++) { if (notas[f] < notas[f + 1]) { int auxnota; auxnota = notas[f]; notas[f] = notas[f + 1]; notas[f + 1] = auxnota; string auxnombre; auxnombre = nombres[f]; nombres[f] = nombres[f + 1]; nombres[f + 1] = auxnombre; } } } } public void Imprimir() { Console.WriteLine("Nombres de alumnos y notas de mayor a menor"); for(int f=0;f < notas.Length;f++) { Console.WriteLine(nombres[f] + " - " + notas[f]); } Console.ReadLine(); } static void Main(string[] args) { PruebaVector16 pv = new PruebaVector16(); pv.Cargar(); pv.Ordenar(); pv.Imprimir(); } } }
Definimos los dos vectores:
private string[] nombres; private int[] notas;
Creamos los dos vectores paralelos con cinco elementos cada uno:
nombres=new string[5]; notas=new int[5];
En el proceso de ordenamiento dentro de los dos for verificamos si debemos los elementos del vector notas:
for (int k = 0; k < notas.Length; k++) { for (int f = 0; f < notas.Length - 1 - k; f++) { if (notas[f] < notas[f + 1]) {
En el caso que la nota de la posición 'f' sea menor a de la posición siguiente 'f+1' procedemos a intercambiar las notas:
int auxnota; auxnota = notas[f]; notas[f] = notas[f + 1]; notas[f + 1] = auxnota;
y simultánemamente procedemos a intercambiar los elementos del vector paralelo (con esto logramos que los dos vectores continuen siendo vectores paralelos):
string auxnombre; auxnombre = nombres[f]; nombres[f] = nombres[f + 1]; nombres[f + 1] = auxnombre;
Como vemos utilizamos dos auxiliares distintos porque los elementos de los dos vectores son de distinto tipo (int y string)
Si deseamos ordenar alfabéticamente la condición dependerá del vector nombres.
Problemas propuestos
- Cargar en un vector los nombres de 5 paises y en otro vector paralelo la cantidad de habitantes del mismo. Ordenar alfabéticamente e imprimir los resultados. Por último ordenar con respecto a la cantidad de habitantes (de mayor a menor) e imprimir nuevamente.
No hay comentarios:
Publicar un comentario