package com.trifulcas.colecciones;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
public class SolucionesColecciones {
public static void main(String[] args) {
HashMap<String, Integer> notas = new HashMap<>();
notas.put("JS", 5);
notas.put("c#", 8);
notas.put("Java", 9);
System.out.println(calculaMedia(notas));
System.out.println(100 / 3.0);
HashMap<String, ArrayList<Integer>> productos = new HashMap<>();
productos.put("Tuerca", new ArrayList<>());
productos.get("Tuerca").add(1);
productos.get("Tuerca").add(2);
productos.get("Tuerca").add(3);
productos.put("Tornillo", new ArrayList<>(Arrays.asList(2, 3, 4)));
productos.put("Arandela", new ArrayList<>(Arrays.asList(4, 5, 6)));
System.out.println(productos);
System.out.println(precioMinimo(productos));
}
static double calculaMedia(HashMap<String, Integer> notas) {
double suma = 0;
// Recorro los valores que es lo que me hace falta
for (int nota : notas.values()) {
suma += nota;
}
// Redondear a dos decimales OJO cuando en java dividimos dos enteros nos hace
// la división entera
// Por lo tanto quita los decimales. Si queremos conservarlos ponemos .0
return Math.round((suma / notas.size()) * 100) / 100.0;
}
// Ojo con los parámetros de entrada y salida
static HashMap<String, Integer> precioMinimo(HashMap<String, ArrayList<Integer>> productos) {
HashMap<String, Integer> res = new HashMap<String, Integer>();
// Recorro el hashmap
for (String producto : productos.keySet()) {
// Añado la clave la misma y el valor aprovecho el min de collections
res.put(producto, Collections.min(productos.get(producto)));
// Si no me acuerdo del collections me creo yo la función
res.put(producto, minimoValor(productos.get(producto)));
}
return res;
}
// No hace falta pero bueno...
static int minimoValor(ArrayList<Integer> numeros) {
int minimo = numeros.get(0);
for (int numero : numeros) {
if (numero < minimo) {
minimo = numero;
}
}
return minimo;
}
}
Ejercicios preexamen
# vamos a hacer una función a la que le pasamos un tipo de bono
# un tipo de cliente y una cantidad y nos calcule el precio de acuerdo a lo siguiente
# bono=vip precio=3000
# bono=extra precio=2000
# bono=normal precio=1000
# tipo cliente= standard, el precio no cambia
# tipo cliente=premium, el precio es la mitad
# por defecto el bono sea normal y el cliente tambien
# los parámetros por defecto siempre al final
def precioTotal(cantidad, tipoBono="normal", tipoCliente="normal"):
if tipoBono == "normal":
precio = 1000
elif tipoBono == "extra":
precio = 2000
else:
precio = 3000
if tipoCliente == "premium":
precio = precio / 2
return cantidad * precio
print(precioTotal(10, "normal", "normal"))
print(precioTotal(10, "normal", "premium"))
print(precioTotal(10, "vip", "premium"))
print(precioTotal(10))
# esta función, en teoría, cuenta el número de pares que hay en la lista
# ¿Funciona? Si es que no por qué y como arreglarlo
def contarPares(lista):
total=0
for i in lista:
if total%2==0:
total+=i
return total
def contarPares(lista):
total = 0
for i in lista:
if i % 2 == 0:
total += 1
return total
# Una función a la que le pasamos un proyecto como este:
proyecto = [
{"nombre": "Análisis", "horas": 10, "precio": 60},
{"nombre": "Desarrollo", "horas": 50, "precio": 50},
{"nombre": "Implementación", "horas": 5, "precio": 70},
{"nombre": "Pruebas", "horas": 15, "precio": 40},
]
# Y nos devuelve una lita de las tareas que ocupan más de 10 horas. En el caso anterior, desarrollo y pruebas
# tareasLargas(proyecto)->["Desarrollo","Pruebas"]
def tareasLargas(proyecto):
res=[]
for tarea in proyecto:
if tarea["horas"]>10:
res.append(tarea['nombre'])
return res
print(tareasLargas(proyecto))
# una función a la que le pasamos una cadena y nos devuelve una lista con la última letra de cada palabra
# ultimaLetra("hola que tal")->["a","e","l"]
def ultimaLetrafor(cadena):
palabras=cadena.split()
res=[]
for palabra in palabras:
res.append(palabra[-1])
return res
def ultimaLetra(cadena):
return [palabra[-1] for palabra in cadena.split()]
print(ultimaLetra("hola que tal"))
Soluciones ejercicios funciones
# Crear una función areaCuadrado(lado) a la que le pasamos un lado y nos devuelve el área
# areaCuadrado(2)-> 4
def areaCuadrado(lado):
return lado*lado
# Crear una función a la que le pasamos un número y nos devuelve true si es divisible por
# 3 y false en caso contrario
# multiploTres(8)->False multiploTres(9)->True
def multiploTres(numero):
return numero % 3==0
"""
if numero % 3==0:
return True
else:
return False
"""
# Crear una función a la que le pasamos una lista de números y nos dice
# el número de pares que hay
# numeroPares([1,2,3,4])->2
def numeroPares(lista):
contador=0
# recorrer la lista
for numero in lista:
# cada vez que haya un par contarlo
if numero % 2 == 0:
contador += 1
return contador
# Crear una función a la que le pasamos una cadena y un carácter y nos devuelve una lista
# con las palabras que tienen ese caracter
# buscaCaracter("Hola que tal","a")->["hola","tal"]
# buscaCaracter("Hola que tal","u")->["que"]
def buscaCaracter(cadena,caracter):
res=[]
# recorrer las palabras
for palabra in cadena.split():
# Si en esas palabras está el caracter lo añado a res
# Si no está, no hago nada
if caracter in palabra:
res.append(palabra)
return res
# Crear una función a la que le pasamos una cadena y nos devuelve la lista de palabras
# ordenada por longitud
# TODO: Preguntar que hacer si la longitud de dos cadenas es igual
def ordenarCadena(cadena):
# obtener la lista de palabras
palabras=cadena.split()
palabras=sorted(palabras,key=len)
return palabras
Más ejemplos diccionarios anidados
# Así defino un diccionario
libro = {"titulo": "El Quijote", "autor": "Cervantes", "precio": 20}
# así accedo al valor de una clave
print(libro["precio"])
# Así recorro todas las claves
for clave in libro:
print(clave)
# los valores de esa clave
print(libro[clave])
# Puedo tener una lista de diccionarios
biblioteca = [
{"titulo": "El Quijote", "autor": "Cervantes", "precio": 20},
{"titulo": "Las olas", "autor": "Virginia Woolf", "precio": 17},
{"titulo": "Los detectives salvajes", "autor": "Roberto Bolaño", "precio": 23},
{"titulo": "Tom va a la escuela", "autor": "Rick Sánchez", "precio": 10}
]
# para acceder a un elemento primero accedo a la posición de la lista
print(biblioteca[1]) # {"titulo": "Las olas", "autor": "Virginia Woolf", "precio": 17},
print(biblioteca[1]["autor"]) # "Virginia Woolf"
# Recorrer esa lista de diccionarios
for libro in biblioteca:
print(libro)
# Quiero ver todos los autores de la biblioteca
for libro in biblioteca:
print(libro["autor"])
# Puedo hacer cálculos por ejemplo media de precios
suma = 0
for libro in biblioteca:
suma += libro["precio"]
print(suma / len(biblioteca))
proyecto = [
{"nombre": "Análisis", "horas": 10, "precio": 60},
{"nombre": "Desarrollo", "horas": 50, "precio": 50},
{"nombre": "Implementación", "horas": 5, "precio": 70},
{"nombre": "Pruebas", "horas": 15, "precio": 40},
]
# función que me calcule el total de importe del proyecto
def totalProyecto(proyecto):
total = 0
# recorro las tareas
for tarea in proyecto:
# Accedo a las propiedades que me interesan. En este caso horas y precio
total += tarea["horas"] * tarea["precio"]
return total
print(totalProyecto(proyecto))
# listas que tienen diccionarios que tienen listas de diccionarios
biblioteca = [
{"titulo": "El Quijote",
"autor": {"nombre": "Miguel de Cervantes", "pais": "España"},
"ediciones": [
{"editorial": "Alianza", "precio": 15},
{"editorial": "Cátedra", "precio": 20}
]
},
{"titulo": "2666",
"autor": {"nombre": "Roberto Bolaño", "pais": "Chile"},
"ediciones": [
{"editorial": "Anagrama", "precio": 30},
{"editorial": "Alfaguara", "precio": 28}
]
}
]
# Al precio de la primera edición de mi primer libro
print(biblioteca[0]["ediciones"][0]["precio"]) # 15
# Al precio de la segunda edición de mi segundo libro
print(biblioteca[1]["ediciones"][1]["precio"]) # 28
# Si quiero el total de precios de toda la biblioteca
# Tengo que recorrer los libros
# después recorrer las ediciones
# sumar los precios
def sumaPreciosBiblioteca(biblioteca):
suma=0
for libro in biblioteca:
for edicion in libro["ediciones"]:
suma+=edicion["precio"]
return suma
print(sumaPreciosBiblioteca(biblioteca))
Ejemplos clase Collection
package com.trifulcas.colecciones;
import java.util.ArrayList;
import java.util.Collections;
public class EjemplosCollection {
public static void main(String[] args) {
ArrayList<String> nombres = new ArrayList<String>();
nombres.add("Juan");
nombres.add("María");
Collections.addAll(nombres, "Pedro", "Luis");
System.out.println("Hemos añadido elementos sueltos en una sola línea");
System.out.println(nombres); // [Juan, María, Pedro, Luis]
System.out.println("Invertimos el arrayList");
Collections.reverse(nombres);
System.out.println(nombres); // [Luis, Pedro, María, Juan]
System.out.println("Ordenamos el arrayList");
Collections.sort(nombres);
System.out.println(nombres); // [Juan, Luis, María, Pedro]
System.out.println("Si está ordenado podemos usar binarySearch");
System.out.println(Collections.binarySearch(nombres, "Pedro"));
System.out.println("Desordenamos el arrayList");
Collections.shuffle(nombres);
System.out.println(nombres); //
// Intercambiamos los valores de dos posiciones
Collections.swap(nombres, 1, 2);
System.out.println("Intercambiar posición 1 y 2");
System.out.println(nombres); //
System.out.println("Podemos obtener el máximo");
System.out.println(Collections.max(nombres)); //Pedro
System.out.println("Y el mínimo");
System.out.println(Collections.min(nombres)); //Juan
System.out.println("Rellenar toda la lista con un valor");
Collections.fill(nombres, "Ana");
System.out.println(nombres);
ArrayList<Integer> numeros=new ArrayList<>();
Collections.addAll(numeros, 1,2,2,3,3,3,4,4,4,4);
System.out.println("Frecuencia (numero de apariciones) de un elemento en una lista");
System.out.println(numeros);
System.out.println(Collections.frequency(numeros, 3));
}
}
Ejemplos tipos genéricos
package com.trifulcas.colecciones;
public class EjemplosGenericos {
public static void main(String[] args) {
// Al ser tipo int llama a la primera función
System.out.println(mayor(4,3));
// Al ser tipo dobule llama a la segunda
System.out.println(mayor(4.6,3.5));
// Llamo a la función con parámetros de tipo double
System.out.println(mayorG(4.6,3.5));
// Llamo a la función con parámetros de tipo int
System.out.println(mayorG(3,4));
// Llamo a la función con parámetros de tipo String
System.out.println(mayorG("ana","pep"));
}
// Esta función tiene de tipo int
static int mayor(int a, int b) {
if (a>b) {
return a;
}
return b;
}
// Esta función es una sobrecarga con double
static double mayor(double a, double b) {
if (a>b) {
return a;
}
return b;
}
// Aquí utilizo un tipo genérico, puedo llamar a la función
// Con cualquier tipo (siempre que se pueda comparar, que eso es lo que significa extends Comparable<T>)
static <T extends Comparable<T>> T mayorG(T a, T b){
if (a.compareTo(b)>0) {
return a;
}
return b;
}
}
Ejemplos HashSet
package com.trifulcas.colecciones;
import java.util.HashSet;
public class EjemplosHashSet {
public static void main(String[] args) {
// Lo creamos con HashSet igual que cualquier colección
HashSet<String> alumnos = new HashSet<>();
// añado los elementos con add
alumnos.add("Ana");
alumnos.add("Eva");
alumnos.add("Pep");
System.out.println("Imprimo el conjunto entero");
System.out.println(alumnos);
// Si añado un elemento que ya existe es como si no hiciera nada
alumnos.add("Ana");
System.out.println("Al añadir Ana no cambia porque ya estaba");
System.out.println(alumnos);
System.out.println("Contains me devuelve true porque Ana está en el conjunto");
System.out.println(alumnos.contains("Ana"));
System.out.println("Recorro los elementos del conjunto");
for (String alumno : alumnos) {
System.out.println(alumno);
}
System.out.println("Elimino el valor de Ana");
alumnos.remove("Ana");
System.out.println(alumnos);
}
}
Un ejemplo de HashMap
package com.trifulcas.colecciones;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
public class UsosHashMap {
public static void main(String[] args) {
ArrayList<String> usuarios=new ArrayList<>();
Collections.addAll(usuarios, "Ana","Eva","Juan","Rosa","Pep","Sara");
System.out.println(generaClaves(usuarios));
HashMap<String,ArrayList<Integer>> hash02=new HashMap<>();
hash02.put("Ana", new ArrayList<>());
hash02.get("Ana").add(5);
hash02.get("Ana").add(7);
hash02.get("Ana").add(9);
hash02.put("Eva", new ArrayList<>());
hash02.get("Eva").add(6);
hash02.get("Eva").add(8);
hash02.get("Eva").add(10);
System.out.println(getMedias(hash02));
}
// Una función a la que le pasamos un arraylist de nombres y nos genera
// Un diccionario con la clave el nombre y un valor que será una contraseña
// basada en el nombre, la primera letra del nombre, el índice del arraylist
// y la última letra del nombre
// generaClaves(ArrayList)
static HashMap<String,String> generaClaves(ArrayList<String> usuarios){
HashMap<String,String> res=new HashMap<String,String>();
for (int i=0;i<usuarios.size();i++) {
String usuario=usuarios.get(i);
String password=usuario.substring(0,1)+i+usuario.substring(usuario.length()-1);
res.put(usuarios.get(i), password);
}
return res;
}
// Una función a la que le pasamos un diccionario con el nombre de un alumno
// Y el valor un arraylist de notas y nos devuelve el hashmap con las medias
static HashMap<String,Double> getMedias(HashMap<String,ArrayList<Integer>> notas){
HashMap<String,Double> res=new HashMap<String,Double>();
for(String alumno:notas.keySet()) {
double suma=0;
for(int nota: notas.get(alumno)) {
suma+=nota;
}
res.put(alumno, suma/notas.get(alumno).size());
}
return res;
}
}
Ejemplos HashMap
package com.trifulcas.colecciones;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map.Entry;
public class EjemplosHashMap {
public static void main(String[] args) {
// Creo un hashmap de clave cadena y valor integer
HashMap<String, Integer> diccionario = new HashMap<String, Integer>();
// Añado valores
diccionario.put("Ana", 7);
diccionario.put("Eva", 8);
diccionario.put("Rosa", 6);
// Recupero valores
System.out.println(diccionario.get("Ana"));
System.out.println(diccionario.get("Pep"));
// Compruebo si existe una clave (en este caso no)
System.out.println(diccionario.containsKey("Pep"));
// Recorro las claves
for (String clave : diccionario.keySet()) {
// COn la clave tengo el valor vía get
System.out.println(clave + " - " + diccionario.get(clave));
}
// Recorro solo los valores
for (Integer valor : diccionario.values()) {
System.out.println(valor);
}
// Recorro el par clave valor con entryset
for (Entry<String, Integer> entrada : diccionario.entrySet()) {
System.out.println(entrada.getKey()+" - "+entrada.getValue());
}
// Eliminar elementos
diccionario.remove("Rosa");
System.out.println(diccionario);
// Cambio un valor
diccionario.put("Ana",9);
System.out.println(diccionario);
// Borro todo el hasmap
diccionario.clear();
System.out.println(diccionario);
// Yo puedo hacer hashmap de cualquier cosa
HashMap<Integer,String> hash01=new HashMap<>();
hash01.put(27, "Hola");
hash01.put(19, "Adios");
System.out.println(hash01);
// Un hashmap que tiene como valores un arraylist
HashMap<String,ArrayList<Integer>> hash02=new HashMap<>();
hash02.put("Ana", new ArrayList<>());
hash02.get("Ana").add(5);
hash02.get("Ana").add(7);
hash02.get("Ana").add(9);
hash02.put("Eva", new ArrayList<>());
hash02.get("Eva").add(6);
hash02.get("Eva").add(8);
hash02.get("Eva").add(10);
System.out.println(hash02);
for(String alumno:hash02.keySet()) {
System.out.println(alumno);
for(int nota:hash02.get(alumno)) {
System.out.println(nota);
}
}
// El primer elemento del alumno "Ana"
System.out.println(hash02.get("Ana").get(0));
}
}
Soluciones ejercicios
package com.trifulcas.colecciones;
import java.util.ArrayList;
import java.util.LinkedList;
public class SolucionesEjercicios {
public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println(tablaMultiplicar(7));
System.out.println(menoresQue(new int[] { 1, 2, 3, 4, 5, 6 }, 4));
System.out.println(menoresQue(new String[] { "hola","que","tal","estamos" }, 4));
LinkedList<Integer> a=new LinkedList<Integer>();
a.add(1);
a.add(2);
a.add(3);
a.add(4);
LinkedList<Integer> b=new LinkedList<Integer>();
b.add(3);
b.add(4);
b.add(5);
b.add(6);
System.out.println(diferencia(a,b));
}
/*
* Crear una función tablaMultiplicar(numero) a la que le pasamos un número y
* nos devuelve un arraylist con la tabla de multiplicar de ese número
* tablaMultiplicar(5)->[5,10,15,20,25,30,35,40,45,50]
*/
static ArrayList<Integer> tablaMultiplicar(int numero) {
ArrayList<Integer> res = new ArrayList<Integer>();
for (int i = 1; i <= 10; i++) {
res.add(i * numero);
}
return res;
}
/*
* Crear una función menoresQue a la que le pasamos un array de enteros y un
* entero y nos devuelve un arraylist con los números menores o iguales a ese
* entero menoresQue([1,2,3,4,5,6],4)->[1,2,3,4]
*/
static ArrayList<Integer> menoresQue(int[] lista, int limite) {
ArrayList<Integer> res = new ArrayList<Integer>();
for (int numero : lista) {
if (numero <= limite) {
res.add(numero);
}
}
return res;
}
/*
* Crear una sobrecarga con String que nos devuelva las cadenas de longitud
* menor o igual al entero menoresQue(["Eva","Ana","Jaimito"],4)->["Eva","Ana"]
*/
static ArrayList<String> menoresQue(String[] lista, int limite) {
ArrayList<String> res = new ArrayList<String>();
for (String cadena : lista) {
if (cadena.length() <= limite) {
res.add(cadena);
}
}
return res;
}
/*
* Crear una función diferencia a la que le pasamos dos
* linkedlist de enteros y nos devuelve un linkedlist
* con los elementos del primer linkedlist que no están
* en el segundo
diferencia([1,2,3,4],[3,4,5,6])->[1,2]
*/
static LinkedList<Integer> diferencia(LinkedList<Integer> a, LinkedList<Integer> b){
LinkedList<Integer> res=new LinkedList<Integer>();
for (int numero:a) {
if (!b.contains(numero)) {
res.add(numero);
}
}
return res;
}
}