package com.trifulcas.arrays;
import java.util.Arrays;
public class FuncionesArrays {
public static void main(String[] args) {
int[] numeros= {1,2,4,5,2,7,8,4};
// Me imprime la dirección de memoria
System.out.println(numeros);
// Imprimimos el array como hacíamos en JS
System.out.println(Arrays.toString(numeros));
// Ordena el array ascendente
Arrays.sort(numeros);
System.out.println(Arrays.toString(numeros));
int[]a= {1,2,3};
int[]b= {1,2,3};
// a y b no son iguales porque apuntan a direcciones de memoria diferentes
System.out.println(a==b);
// Pero a y b son iguales en valor, el equals lo comprueba
System.out.println(Arrays.equals(a, b));
// Estoy copiando los 6 primeros elementos de numeros en copia
int[] copia=Arrays.copyOf(numeros, 6);
System.out.println(Arrays.toString(copia));
// Estoy copiando lo elementos desde la posición 2 a la 6 (no incluída)
int[] otraCopia=Arrays.copyOfRange(numeros, 2,6);
System.out.println(Arrays.toString(otraCopia));
// Relleno todo el array con el valor 7
Arrays.fill(a, 7);
System.out.println(Arrays.toString(a));
// Hago una búsqueda del numero 7 en el array. Me devuelve la posición
System.out.println(Arrays.binarySearch(numeros, 7));
}
}
Más ejemplos array
package com.trifulcas.arrays;
public class EjemplosArrays {
public static void main(String[] args) {
int[] rango=crearRango(3);
// foreach de java
for(int i:rango) {
System.out.println(i);
}
// Clonar (copiar) el array
int[] copia=rango.clone();
// Modifico la copia
copia[0]=9;
// No modifica el original
for(int i:rango) {
System.out.println(i);
}
for(int i:copia) {
System.out.println(i);
}
}
// Tengo una función que me devuelve un array
static int[] crearRango(int tam) {
// Cuando creo el array le digo el tamaño
int[] res=new int[tam];
for(int i=0;i<tam;i++) {
res[i]=i+1;
}
return res;
}
}
Intro arrays
package com.trifulcas.arrays;
public class IntroArrays {
public static void main(String[] args) {
int[] tablaEnteros; // Un array de enteros sin incializar
int[] otraTabla= new int[5]; // Un array de enteros de tamaño 5
int[] ultimaTabla= {1,2,3,4,5}; // Un array lo creo y lo inicializo
System.out.println(ultimaTabla[1]); // 2
ultimaTabla[3]=99; // {1,2,3,99,5}
for(int i=0;i<ultimaTabla.length;i++) {
System.out.println(ultimaTabla[i]);
}
for(int i=0;i<otraTabla.length;i++) {
System.out.println(otraTabla[i]);
}
/* da error
for(int i=0;i<tablaEnteros.length;i++) {
System.out.println(tablaEnteros[i]);
}
*/
tablaEnteros=ultimaTabla; // Asignando un array a otro array
// Se copia la referencia, no el array
// Si modificamos cualquiera de los dos arrays
// Se modifica el otro
tablaEnteros[0]=666;
for(int i=0;i<ultimaTabla.length;i++) {
System.out.println(ultimaTabla[i]);
}
// Nos imprime el mismo valor porque están apuntando al mismo sitio
System.out.println(tablaEnteros);
System.out.println(ultimaTabla);
int[] numeros= {1,2,3,4,5,6,7,8,9,10};
for(int i=0;i<numeros.length;i++) {
System.out.println(numeros[i]);
}
System.out.println(sumaTabla(numeros));
// Al llamar a la función sumaTabla me ha modificado numeros fuera
// de la función
for(int i=0;i<numeros.length;i++) {
System.out.println(numeros[i]);
}
}
// UN array se pasa por referencia, no por valor. NO SE COPIA
static int sumaTabla(int[] elementos) {
// como modifico la tabla que paso, se modifica fuera
for(int i=1;i<elementos.length;i++) {
elementos[0]+=elementos[i];
}
return elementos[0];
}
}
Solución ejercicios cadenas
package com.trifulcas.cadenas;
public class EjerciciosCadenas {
public static void main(String[] args) {
System.out.println(eliminar("que queso es un paquete", "que"));
System.out.println(contarChar("hola que tal", 'a'));
System.out.println(contarChar2("hola que tal", 'a'));
System.out.println(sinEspacios(" hola que tal "));
System.out.println(sinEspaciosMejor(" hola que tal "));
System.out.println(masCorta("hola que tal","bbien"));
}
/*
* Escribir una función que elimine todas las ocurrencias de una subcadena
* específica de una cadena dada.
* eliminar("que queso es un paquete","que")–>" so es un pate"
*/
static String eliminar(String cadena, String cadenaAEliminar) {
// Simplemente reemplazo la cadena con la cadena vacía
return cadena.replace(cadenaAEliminar, "");
}
/*
* Escribir una función que cuente el número de veces que se repite un carácter
* específico en una cadena dada. contarChar("hola que tal",'a')–>2
*/
static int contarChar(String cadena, char caracter) {
int cont = 0;
// Recorro toda la cadena
for (int i = 0; i < cadena.length(); i++) {
// Si el caracter en esa posición es igual al caracter que me pasan
if (cadena.charAt(i) == caracter) {
cont++; // Cuento 1 más
}
}
return cont;
}
static int contarChar2(String cadena, char caracter) {
// Elimino el caracter de la cadena y la diferencia entre las longitudes
// Es las veces que aparece
// mañana (6) mñn (3) 6-3=3 veces aparece 'a'
// Ojo porque como Java es tipado tenemos que hacer conversiones de tipo
// Strng.valueOf(char) Nos convierte un char en cadena
return cadena.length() - cadena.replace(String.valueOf(caracter), "").length();
}
/*
* Escribir una función que elimine los espacios en blanco al principio y al
* final de una cadena dada, y que si hay espacios dobles en el interior los
* cambie por un solo espacio. sinEspacios(" hola que tal ")–>"hola que tal"
*/
static String sinEspacios(String cadena) {
// Elimino espacios de inicio y fin
cadena = cadena.trim();
// Reemplazo dos espacios por uno
cadena = cadena.replace(" ", " ");
return cadena;
}
static String sinEspaciosMejor(String cadena) {
cadena = cadena.trim();
// Mientras tenga dos espacios consecutivos
while (cadena.indexOf(" ") != -1) {
// Los reduzco a uno
cadena = cadena.replace(" ", " ");
}
// Al salir del bucle no puedo tener dos espacios consecutivos, hemos reducido
// Cualquier cadena de espacios a uno solo
return cadena;
}
/*
* Escribir una función a la que le pasamos dos cadenas y nos devuelva la más corta.
*/
static String masCorta(String cad1, String cad2) {
if (cad1.length()>cad2.length()) {
return cad1;
}
return cad2;
}
}
Ejercicios random
# vamos a crear una función tiradaMoneda() que nos devuelve 'cara' o 'cruz' aleatoriamente # Y otra función tiradaMonedas(veces) que nos devuelva una lista de x tiradas aleatorias # de monedas. tiradaMonedas(3)->["cara","cara","cruz"] # y otra función tiradaFrecuente(tiradas) a la que le pasamos una lista de tiradas y nos # devuelve 'cara' si hay más caras que cruces 'cruz' si hay más cruces que caras y 'empate' # si hay la misma cantidad
Funciones matemáticas
import math
# constantes
print(math.pi)
print(math.e)
print(math.tau)
print(math.inf)
# Funciones trigonométricas
print(math.sin(math.pi)) # seno
print(math.cos(math.pi)) # coseno
print(math.hypot(3,4)) #hipotenusa
# Funciones exponenciales
print(math.pow(2,10)) # 2 elevado a 10
print(math.sqrt(65536)) # raiz cuadrada
print(math.isqrt(101)) # raiz cuadrada entera
# Funciones logarítmicas
print(math.log10(100)) # logaritmo en base 10
print(math.log2(1024)) # logaritmo en base 2
print(math.log(10)) # logaritmo en base natural (e)
print(math.log(10,3)) # logaritmo en cualquier base
# Funciones de redondeo y truncamiento
print(math.ceil(3.4)) # entero más alto: 4
print(math.ceil(-3.4)) # entero más alto: -3
print(math.floor(3.4)) # entero más bajo: 3
print(math.floor(-3.4)) # entero más bajo: -4
print(math.trunc(3.4)) # parte entera 3
print(math.trunc(-3.4)) # parte entera -3
# redondeo correcto
inicio=0.5
for i in range(6):
print(inicio+i,round(inicio+i),math.trunc(inicio+i+.5),int((inicio+i+.5)))
# curiosas
print(math.factorial(8)) # 8!
print(math.gcd(4,10)) # máximo común divisor
Módulo random
import random
print(random.randint(1,100)) # Número aletorio entre 1 y 100
print(random.random()) # Númer aleatorio entre 0 y 1 (1 no incluído)
print(round(random.random()*100)+1) # Númer aleatorio entre 0 y 1 (1 no incluído)
#random.seed(50) # pongo una semilla porque son números pseudoaletorios
print(random.randint(1,100)) # Número aletorio entre 1 y 100
tiradas=[]
for i in range(20):
tiradas.append(random.randint(1,6))
print(tiradas)
alumnos=["Pau","Sandra","Glen","Renata","Juan"]
print(random.choice(alumnos)) # Me devuelve un alumno al azar
print(random.sample(alumnos,2)) # me devuelve una muestra de dos alumnos al azar
random.shuffle(alumnos) # desordena la lista
print(alumnos)
# recorro la lista desordenada
for alumno in alumnos:
print(alumno)
# me devuelve un número decimal entre 2.5 y 5.5 con distribución uniforme
# es decir, todos tienen la misma probabilidad de aparecer
print(random.uniform(2.5, 5.5))
# Esto con una gaussiana indicando mu y sigma
print(random.gauss(0, 3))
Módulos propios en Python
# importar todo un módulo
import utilidades
print(utilidades.contarVocales("hola"))
# importar todo un módulo renombrándolo
import utilidades as ut
print(ut.contarVocales("hola"))
# importar solo una función
from utilidades import contarVocales
print(contarVocales("hola ue tal"))
Soluciones ejercicios diccionario
votaciones = [
{
"votante": "Juan",
"votos": [
{"participante": "Ana", "puntos": 5},
{"participante": "Pedro", "puntos": 3}
]
},
{
"votante": "Marta",
"votos": [
{"participante": "Ana", "puntos": 4},
{"participante": "Luis", "puntos": 2}
]
},
{
"votante": "Pedro",
"votos": [
{"participante": "Ana", "puntos": 3},
{"participante": "Luis", "puntos": 5}
]
}
]
# crear una función que nos devuelva una lista de participantes ordenada de
# más votos a menos votos
# para cada participante el número de votos que tiene
# ¿Puedo imprimir cada participante con su voto?
# Lo tengo que guardar en alguna parte: en un diccionario
def listaVotosRedundante(votaciones):
resultado = {}
for votacion in votaciones:
# print(votacion["votos"])
for voto in votacion["votos"]:
resultado[voto["participante"]] = 0
print(resultado)
for votacion in votaciones:
# print(votacion["votos"])
for voto in votacion["votos"]:
resultado[voto["participante"]] += voto["puntos"]
print(resultado)
return sorted(resultado,key=resultado.get,reverse=True)
def listaVotos(votaciones):
# Guardo los datos en un diccionario
resultado = {}
# recorro las votaciones
for votacion in votaciones:
# Dentro de las votaciones recorro los votos
for voto in votacion["votos"]:
# Si el participante ya lo tengo en el diccionario sumo los puntos
if voto["participante"] in resultado:
resultado[voto["participante"]] += voto["puntos"]
else:
# Si no está lo creo con los puntos de esta votación
# No puedo sumar los puntos si no existe de antes
resultado[voto["participante"]] = voto["puntos"]
# Ordeno las claves del diccionario (que son los participantes) por su valor (que son los votos)
return sorted(resultado, key=resultado.get, reverse=True)
print(listaVotos(votaciones))
# Crear una función que nos devuelva un diccionario con
# la clave el nombre del votante y el valor la media de sus votos
# recorrer todos los votantes
def mediaVotos(votaciones):
votantes={}
# al final de lo que ponga aquí en mi diccionario tendré
# el nombre de los votantes y de momento ponemos 0
for votacion in votaciones:
suma=0
# Sumo todos sus puntos
for voto in votacion["votos"]:
suma+=voto["puntos"]
# la media es la suma divido entre el número de votos
votantes[votacion["votante"]] = suma/len(votacion["votos"])
return votantes
print(mediaVotos(votaciones))
Ejemplo Palindromo y test
System.out.println(palindromo("Arriba la birra"));
System.out.println(palindromo("Arriba mi birra"));
System.out.println(palindromo("Isaac no ronca asi"));
System.out.println(palindromo("En un lugar de la mancha"));
StringBuilder sbuilder = new StringBuilder();
long inicio = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
sbuilder.append("Elefante");
}
long fin = System.currentTimeMillis();
System.out.println("Tiempo del StringBuilder: " + (fin - inicio));
String cadena = "";
inicio = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
cadena += "Elefante";
}
fin = System.currentTimeMillis();
System.out.println("Tiempo del String: " + (fin - inicio));
}
// Esta función nos dice si una cadena es o no un palíndromo
// Se lee igual de principio a final que a la inversa
// Ejemplo: Arriba la birra
static boolean palindromo(String cadena) {
// Igual a si misma dada la vuelta
// Creo el stringbuilder
StringBuilder cadsb = new StringBuilder(cadena.toLowerCase().replace(" ", ""));
// Creo otro igual
StringBuilder cadsb2 = new StringBuilder(cadsb);
// Le doy la vuelta
cadsb2.reverse();
// Y los comparo
return cadsb.compareTo(cadsb2) == 0;
}