Autor: Juan Pablo Fuentes
Formador de programación y bases de datos
Ejemplos funciones LinkedList
package com.trifulcas.colecciones; import java.util.LinkedList; public class FuncionesLinkedList { public static void main(String[] args) { // TODO Auto-generated method stub System.out.println(creaLista(6)); LinkedList<Integer> numeros=new LinkedList<Integer>(); numeros.add(1); numeros.add(2); numeros.add(3); System.out.println(numeros); System.out.println(invertir(numeros)); String[] alumnos= {"Ana","Eva","Pepe","Rosa"}; System.out.println(alumnosPares(alumnos)); } // Crear una función a la que le pasamos un limite y nos crea una lista // de la forma 1 2 3 4 5 4 3 2 1 static LinkedList<Integer> creaLista(int limite){ LinkedList<Integer> res=new LinkedList<Integer>(); res.add(limite); for(int i=limite-1;i>0;i--) { res.addFirst(i); res.addLast(i); } return res; } // Crear una función a la que le pasamos un linkedList y nos devuelve // una linkedlist con los elementos invertidos static LinkedList<Integer> invertir(LinkedList<Integer> lista){ LinkedList<Integer> res=new LinkedList<Integer>(); for(int i:lista) { res.push(i); } return res; } // Crear una función a la que le pasamos un array de alumnos (Strings) // y nos devuelve un linkedlist de los alumnos que están en la posición par static LinkedList<String> alumnosPares(String[] alumnos){ LinkedList<String> res= new LinkedList<String>(); for(int i=0;i<alumnos.length;i++) { if (i%2==0) { res.add(alumnos[i]); } } return res; } }
LinkedList
package com.trifulcas.colecciones; import java.time.LocalDate; import java.util.LinkedList; import java.util.List; public class EjemplosLinkedList { public static void main(String[] args) { LinkedList<String> lista = new LinkedList<String>(); // Lo mismo pero no especifico tipo LinkedList<String> lista2 = new LinkedList<>(); // Lo mismo pero usando la clase abstracta List<String> lista3 = new LinkedList<String>(); // Muy importante: el tipo tiene que ser una clase // LinkedList<int> enteros=new LinkedList<int>(); // Utilizar unas clases 'wrapper' (envolventes) // Que son lo mismo que los tipos primitivos pero en clase LinkedList<Integer> enteros = new LinkedList<Integer>(); LinkedList<Boolean> boleanos = new LinkedList<Boolean>(); LinkedList<Double> decimales = new LinkedList<Double>(); // No especificamos tamaño, porque es dinámico // Yo añado elementos con add, los que quiera enteros.add(5); enteros.add(9); enteros.add(13); System.out.println(enteros); // Puedo recorrer con un for : for (Integer i : enteros) { System.out.println(i); } // Con un for normal usando el size (tamaño) for (int i = 0; i < enteros.size(); i++) { // con get obtenemos el elemento en esa posición System.out.println(enteros.get(i)); } // Podemos usar el foreach enteros.forEach(x -> System.out.println(x)); LinkedList<LocalDate> fechas = new LinkedList<LocalDate>(); fechas.add(LocalDate.now()); // Añadir en un índice determinado enteros.add(1, 666); System.out.println(enteros); // Eliminamos el elemento de la posición 2 enteros.remove(2); System.out.println(enteros); // Si un elemento está dentro el LinkedList System.out.println(enteros.contains(5)); // true System.out.println(enteros.contains(90)); // false // Buscar la posición de un elemento System.out.println(enteros.indexOf(13)); // 2 System.out.println(enteros.indexOf(130)); // -1 porque no lo encuentra // Tenemos una serie de funciones que nos van a recordar a JS // Yo puedo añadir al principio enteros.push(7); System.out.println(enteros); // Recuperar del principio (y se va de la lista) int r = enteros.pop(); System.out.println(enteros); // ver sin eliminar System.out.println(enteros.peekFirst()); System.out.println(enteros.peekLast()); System.out.println(enteros.getFirst()); System.out.println(enteros.getLast()); while (enteros.size() > 0) { System.out.println(enteros.pop()); } for (int i = 2; i < 40; i += 3) { enteros.push(i); } System.out.println(enteros); // Eliminar System.out.println(enteros.poll()); System.out.println(enteros.pollFirst()); System.out.println(enteros.pollLast()); System.out.println(enteros); } }
Ejemplos funciones con ArrayList
package com.trifulcas.colecciones; import java.util.ArrayList; public class FuncionesArrayList { public static void main(String[] args) { int[] lista = { 2, 4, 7, 3, 45, 76, 90, 101 }; ArrayList<Integer> pares = getPares(lista); ArrayList<Integer> otra = new ArrayList<Integer>(); otra.add(4); otra.add(76); otra.add(40); System.out.println(pares); System.out.println(sumaArray(pares)); System.out.println(interseccion(pares,otra)); } // Función a la que le pasamos un array de enteros y nos devuelve los pares static ArrayList<Integer> getPares(int[] numeros) { ArrayList<Integer> res = new ArrayList<Integer>(); for (int i : numeros) { if (i % 2 == 0) { res.add(i); } } return res; } // Función a la que le pasamos un ArrayLIst de enteros y nos devuelve la suma static int sumaArray(ArrayList<Integer> numeros) { int suma = 0; for (int i : numeros) { suma += i; } return suma; } // Función que le pasamos dos arraylist y nos devuelve la intersección de los dos static ArrayList<Integer> interseccion(ArrayList<Integer> a, ArrayList<Integer>b){ ArrayList<Integer> res=new ArrayList<Integer>(); for(int i:a) { if (b.contains(i)) { res.add(i); } } return res; } }
Ejemplos ArrayList
// Sintaxis ArrayList<Tipo de datos> nombre = new ArrayList<Tipo>() ArrayList<String> lista = new ArrayList<String>(); // Lo mismo pero no especifico tipo ArrayList<String> lista2 = new ArrayList<>(); // Lo mismo pero usando la clase abstracta List<String> lista3=new ArrayList<String>(); // Muy importante: el tipo tiene que ser una clase //ArrayList<int> enteros=new ArrayList<int>(); // Utilizar unas clases 'wrapper' (envolventes) // Que son lo mismo que los tipos primitivos pero en clase ArrayList<Integer> enteros=new ArrayList<Integer>(); ArrayList<Boolean> boleanos=new ArrayList<Boolean>(); ArrayList<Double> decimales=new ArrayList<Double>(); // No especificamos tamaño, porque es dinámico // Yo añado elementos con add, los que quiera enteros.add(5); enteros.add(9); enteros.add(13); System.out.println(enteros); // Puedo recorrer con un for : for(Integer i:enteros) { System.out.println(i); } // Con un for normal usando el size (tamaño) for(int i=0;i<enteros.size();i++) { // con get obtenemos el elemento en esa posición System.out.println(enteros.get(i)); } // Podemos usar el foreach enteros.forEach(x->System.out.println(x)); ArrayList<LocalDate> fechas= new ArrayList<LocalDate>(); fechas.add(LocalDate.now()); // Añadir en un índice determinado enteros.add(1,666); System.out.println(enteros); // Eliminamos el elemento de la posición 2 enteros.remove(2); System.out.println(enteros); // Si un elemento está dentro el arraylist System.out.println(enteros.contains(5)); // true System.out.println(enteros.contains(90)); // false // Buscar la posición de un elemento System.out.println(enteros.indexOf(13)); // 2 System.out.println(enteros.indexOf(130)); // -1 porque no lo encuentra
Soluciones fechas
package com.trifulcas.fechas; import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.time.temporal.ChronoUnit; import java.util.Arrays; public class EjerciciosFechas { public static void main(String[] args) { // TODO Auto-generated method stub LocalDate cumple = LocalDate.of(2024, 8, 13); System.out.println(cumple.format(DateTimeFormatter.ofPattern("MM/d/yyyy"))); System.out.println(cuantoFalta(cumple)); System.out.println(Arrays.toString(primerosDeMes(2025))); System.out.println(esFinDeSemanaAnglo("06/01/2024")); System.out.println(esFinDeSemanaEsp("04/06/2024")); } // Crear una función cuantoFalta(fecha) a la que le pasamos una fecha // y nos devuelve cuantos días faltan hasta esa fecha static long cuantoFalta(LocalDate fecha) { return ChronoUnit.DAYS.between(LocalDate.now(), fecha); } // Crear una función primerosDeMes(anyo) que nos devuelva una array con las // fechas // de los primeros de mes de ese año (1 de enero, 1 de febrero, 1 de marzo...) // Devuelvo un array de fechas, le paso un int con el año static LocalDate[] primerosDeMes(int anyo) { // La sintaxis de un array es tipo nombre_variable= new tipo[tamaño] LocalDate[] fechas = new LocalDate[12]; // ¿Por qué 12? Porque son 12 meses // ¿Cómo creo yo un array con los primeros de mes? // (0) 1-1-2024, (1) 1-2-2024, (2) 1-3-2024... for (int i = 1; i <= 12; i++) { fechas[i - 1] = LocalDate.of(anyo, i, 1); } return fechas; } // Crear una función a la que le pasamos una cadena con una fecha en formato // "año-mes-dia" y nos devuelve true si es fin de semana y false en caso // contrario // esFinDeSemana(cadena) static boolean esFinDeSemanaEsp(String cadena) { // Convertir la cadena a fecha LocalDate fechaConvertida = LocalDate.parse(cadena, DateTimeFormatter.ofPattern("dd/MM/yyyy")); // Saber el día de la semana int diaSemana = fechaConvertida.getDayOfWeek().ordinal(); // Si es sábado o domingo devolver true y si no false return diaSemana >= 5; } static boolean esFinDeSemanaAnglo(String cadena) { // Convertir la cadena a fecha LocalDate fechaConvertida = LocalDate.parse(cadena, DateTimeFormatter.ofPattern("MM/dd/yyyy")); // Saber el día de la semana int diaSemana = fechaConvertida.getDayOfWeek().ordinal(); // Si es sábado o domingo devolver true y si no false return diaSemana >= 5; } }
Ejercicios If
# Cread una función a la que le pasamos una cantidad y nos devuelve el PVP # siguiendo las siguientes reglas # Si el precio es <1000 No hay descuento # Está entre 1000 y <3000 5% de descuento # Es 3000 o más 10% de descuento # devuelvo el importe, no el descuento # Cread una función obtenerIRPF(departamento, sueldo) que nos devuelva el % de irpf acorde a: # Si el departamento es 'marketing' 12% # Si el departamento es 'administracion' y el sueldo es <2500 12%, si es mayor 15% # Si el departamento es 'contabilidad' tiene los siguientes tramos: # hasta 3000 10% de 3000 a 5000 12% mas de 5000 15%
Ejemplo función recursiva para buscar un archivo
Probad a crear una carpeta meted un archivo dentro y mirad a ver si lo encuentra
import os def buscar_archivo(ruta, nombre_archivo): """ Busca un archivo con un nombre específico en una carpeta y sus subcarpetas. :param ruta: La ruta de la carpeta en la que iniciar la búsqueda. :param nombre_archivo: El nombre del archivo a buscar. :return: La ruta completa del archivo si se encuentra, de lo contrario None. """ # Recorremos todos los elementos dentro de la carpeta actual for elemento in os.listdir(ruta): # Construimos la ruta completa del elemento ruta_completa = os.path.join(ruta, elemento) # Si el elemento es un archivo y su nombre coincide con el que buscamos if os.path.isfile(ruta_completa) and elemento == nombre_archivo: return ruta_completa # Si el elemento es una carpeta, llamamos recursivamente a la función elif os.path.isdir(ruta_completa): resultado = buscar_archivo(ruta_completa, nombre_archivo) if resultado: return resultado # Si no encontramos el archivo, devolvemos None return None # Ejemplo de uso ruta_busqueda = 'c:\\xampp' nombre_archivo = 'index.html' resultado = buscar_archivo(ruta_busqueda, nombre_archivo) if resultado: print(f'Archivo encontrado en: {resultado}') else: print('Archivo no encontrado')
Ejemplos modulo os
import os # La carpeta en la que estoy directorio_actual = os.getcwd() print(directorio_actual) # Me devuelve una lista de todos los archivos en una carpeta determinada archivos_en_directorio = os.listdir(directorio_actual) print(archivos_en_directorio) # Lista que se puede recorrer for archivo in archivos_en_directorio: print(archivo) if os.path.isfile(archivo): print('Es un archivo.') elif os.path.isdir(archivo): print('Es un directorio.') elif os.path.islink(archivo): print('Es un enlace simbólico.') archivos_en_directorio = os.listdir("c:\\xampp") print(archivos_en_directorio) # Si un archivo existe. Muy útil si yo quiero abrir un archivo print(os.path.exists("c:\\xampp\\pepe.txt")) # False print(os.path.exists("c:\\xampp\\uninstall.dat")) # True porque en mi ordenador sí que existe # Compruebo antes de crear que la carpeta no exista if not os.path.exists("nueva_carpeta"): # Creo la carpeta os.mkdir("nueva_carpeta") # Compruebo que no existe la ruta de carpetas que quiero crear if not os.path.exists("carpeta\\con\\subcarpetas"): # Creo la carpeta con sus subcarpetas os.makedirs("carpeta\\con\\subcarpetas") #Compruebo que existe el archivo if os.path.exists("pais.txt"): # Si existe, lo elimino. OJO CUIDADO no se puede deshacer os.remove("pais.txt") #os.rename("numeros01.txt","numeros1.text") ruta_absoluta = os.path.abspath('prueba.txt') print(ruta_absoluta)
Soluciones fechas
import datetime # crear una función cuantoFalta(fecha) a la que le pasamos una fecha # y nos devuelve cuantos días faltan hasta esa fecha def cuantoFalta(fecha): # Calcular cuantos días faltan hasta la fecha que me pasan # que día es hoy hoy = datetime.datetime.now() # Hago la resta, en python es tan sencillo como restar faltan = fecha - hoy # timedelta que es un periodo de tiempo # De ese periodo de tiempo me interesan los días return faltan.days # La fecha de mi cumpleaños miFecha = datetime.datetime(2024, 8, 13) # ¿Cuanto falta hasta mi cumpleaños? print(cuantoFalta(miFecha)) # 75 # crear una función primerosDeMes(anyo) que nos devuelva una lista con las fechas # de los primeros de mes de ese año (1 de enero, 1 de febrero, 1 de marzo...) def primerosDeMes(anyo): # Crear una lista de fechas res = [] # creo una fecha datetime.date(año,mes,dia) # ¿Cuantas fechas tengo que crear? 12 for i in range(12): res.append(datetime.datetime(anyo, i + 1, 1)) # res.append("01/"+str(i+1)+"/"+str(anyo)) return res print(primerosDeMes(2024)) # [2024-1-1,2024-2-1,....,2024-12-1] print(primerosDeMes(2556)) # [2024-1-1,2024-2-1,....,2024-12-1] fechas = primerosDeMes(2024) for fecha in fechas: print(fecha.strftime("%d/%m/%Y"), cuantoFalta(fecha)) # crear una función a la que le pasamos una cadena con una fecha en formato dia/mes/año # y nos devuelve true si es fin de semana y false en caso contrario # esFinDeSemana(cadena) def esFinDeSemana(cadena): res = False # Pasar de cadena a fecha fecha = datetime.datetime.strptime(cadena, "%d/%m/%Y") if fecha.weekday() >= 5: res = True return res print(esFinDeSemana(("01/06/2024"))) # true print(esFinDeSemana(("04/06/2024"))) # false # crear una función a la que le pasamos un año, un mes y un día y nos devuelve una lista # con todas las horas exactas de ese día # crearAgendaDia(2024,5,1)->[2024-5-1 00:00,2024-5-1 01:00,2024-5-1 02:00,2024-5-1 03:00,...2024-5-1 23:00] def crearAgendaDia(anyo, mes, dia): res = [] # crear una lista con unas horas que van de donde a donde? de 0 a 23 for i in range(24): res.append(datetime.datetime(anyo, mes, dia, i)) return res print(crearAgendaDia(2024, 5, 1)) # [2024-5-1 00:00,2024-5-1 01:00,2024-5-1 02:00,2024-5-1 03:00,...2024-5-1 23:00]