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;
}
}
Categoría: Java
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;
}
Stringbuilder
StringBuilder cad = new StringBuilder("Hola que tal");
System.out.println(cad);
// cad="Yo muy bien"; Esto da un yo estoy
cad.append(" yo estoy muy bien");
System.out.println(cad);
// Comparte métodos con String
System.out.println(cad.length());
System.out.println(cad.substring(5));
System.out.println(cad.substring(5,8));
// Pero permite modificar insertando
cad.insert(0, "hey!");
System.out.println(cad);
// O añadiendo al final
cad.append(" yo estoy muy bien");
// O eliminar posiciones
System.out.println(cad.delete(2, 5));
// Podemos darle la vuelta a la cadena
System.out.println(cad.reverse());
System.out.println(cad.reverse());
// COnvierto un stringbuilder a una cadena
String cad2=cad.toString();
String nombre="Juan";
// Convierto una cadena a Stringbuilder
StringBuilder nombreSB=new StringBuilder(nombre);
System.out.println(nombre);
System.out.println(nombreSB);
// Puedo añadir String o Stringbuilder
nombreSB.append(cad);
System.out.println(nombreSB);
Funciones de cadena
String c = "hola";
String d = "hola";
String e = new String("HOLA");
System.out.println(c == d); // NO COMPARA VALORES
System.out.println(c == e); // COMPARA EL PUNTERO
System.out.println(c.equals(e)); // Compara el valor
System.out.println(c.equalsIgnoreCase(e)); // Compara el valor
c += " que tal";
System.out.println(c);
String alumno1 = "Ana";
String alumno2 = "Pep";
if (alumno1.compareTo(alumno2) > 0) {
System.out.println(alumno1 + " es mayor que " + alumno2);
} else {
System.out.println(alumno2 + " es mayor que " + alumno1);
}
// Longitud
System.out.println(alumno1.length());
// Conversión de mayúsculas
System.out.println(alumno1.toLowerCase()); //ana
System.out.println(alumno1.toUpperCase()); // ANA
c = "En un lugar de la mancha";
// Subcadenas
System.out.println(c.substring(5)); // A partir de la posición 5 hasta el final lugar de la mancha
System.out.println(c.substring(5, 8)); // De la posición 5 hasta la 8 lu
// Inicio y fin
System.out.println(c.startsWith("En")); //true
System.out.println(c.endsWith("cha"));//true
// Acceder a las letras
for (int i = 0; i < c.length(); i++) {
System.out.println(c.charAt(i));
}
// Reemplazar cadenas
System.out.println(c.replace("a", "@"));
System.out.println(c.replace("la", "LA"));
// Buscar cadenas
System.out.println(c.indexOf("un")); // 3
System.out.println(c.indexOf("pepe")); // -1
// Buscar todas las apariciones
int pos = c.indexOf("a");
while (pos != -1) {
System.out.println(pos);
pos = c.indexOf("a", pos + 1);
}
// Saber si hay una subcadena
System.out.println(c.contains("un")); // true
System.out.println(c.contains("pepe")); //false
// Eliminar espacios al principio y al final
c=" hola que tal ";
System.out.println("|"+c+"|");
System.out.println("|"+c.trim()+"|");
Sobrecarga
public class Sobrecarga {
public static void main(String[] args) {
System.out.println(suma(2,3));
System.out.println(suma(2.4,3.6));
System.out.println(suma(2,3,4));
System.out.println(.1 + .2);
System.out.println(repetir("*",9));
System.out.println(repetir("-",20));
System.out.println(repetir("-"));
System.out.println(repetir());
System.out.println(repetir(20));
}
static int suma(int a, int b) {
return a+b;
}
static double suma(double a, double b) {
return a+b;
}
static int suma(int a,int b,int c) {
return a+b+c;
}
static String repetir(String cadena, int veces) {
String res="";
for(int i=0;i<veces;i++) {
res+=cadena;
}
return res;
}
static String repetir(String cadena) {
return repetir(cadena,10);
}
static String repetir() {
return repetir("*",10);
}
static String repetir(int veces) {
return repetir("*",veces);
}
}
Ejemplos funciones
package com.trifulcas.funciones;
public class EjemploFuncion {
public static void main(String[] args) {
int a = doble(8);
System.out.println(a);
saludo("Ana");
/* Esto de aquí da error
saludo(89); Saludo tiene un parámetro String, no le puedo pasar un int
int a=iva(); iva devuelve un double no lo puedo asignar a un int
*/
int b=mayor(3,990);
System.out.println(b);
System.out.println(esPrimo(17));
System.out.println(esPrimo(170));
System.out.println(listaPrimos(50));
}
// static que de momento lo ponemos siempre porque sí
// int que es el tipo que devuelvo: en este caso devuelvo un entero
// doble que es el nombre de la función
// Los parámetros que en este caso es 1 y entero
// return nos devuelve algo, en este caso el doble del número
static int doble(int numero) {
return numero * 2;
}
// Devuelvo un double (con decimales)
// No le paso ningún parámetro
static double iva() {
return .21;
}
// No devuelvo ningún resultado, uso void
static void saludo(String nombre) {
System.out.println("hola "+nombre);
}
static int mayor(int a, int b) {
if (a>b) {
return a;
}else {
return b;
}
}
static boolean esPrimo(int numero) {
for (int i = 2; i < numero; i++) {
if (numero % i == 0) {
return false;
}
}
return true;
}
static String listaPrimos(int numero) {
String res="";
for(int i=2;i<numero;i++) {
if (esPrimo(i)) {
res+=i+" ";
}
}
return res;
}
}
Más ejemplos for
// Calcula a suma de los 100 primeros números
int suma = 0;
for (int i = 0; i <= 100; i++) {
suma += i;
}
System.out.println(suma);
// Calcula el factorial de un número
int numero = 8;
int factorial = 1;
for (int i = 1; i <= numero; i++) {
factorial *= i;
}
System.out.println(factorial);
// Bucle anidado se ejecuta 25 veces (5*5)
for (int i = 0; i < 5; i++) {
for (int j = 0; j < 5; j++) {
System.out.println(i + "-" + j);
}
}
numero = 17;
boolean esPrimo = true;
for (int i = 2; i < numero; i++) {
if (numero % i == 0) {
esPrimo = false;
}
}
if (esPrimo) {
System.out.println(numero + " es primo");
} else {
System.out.println(numero + " no es primo");
}
for (int j = 2; j <= 100; j++) {
esPrimo = true;
for (int i = 2; i < j; i++) {
if (j % i == 0) {
esPrimo = false;
}
}
if (esPrimo) {
System.out.println(j + " es primo");
} else {
System.out.println(j + " no es primo");
}
}
Ejemplos for
// For es igual que en JS
// for(inicializacion;condicion;modificacion)
for (int i = 0; i < 10; i++) {
System.out.println(i);
}
// Puedo ir de dos en dos
for (int i = 0; i < 10; i += 2) {
System.out.println(i);
}
// Puedo ir de atrás adelante
for (int i = 10; i > 0; i--) {
System.out.println(i);
}
// Puedo incluso multiplicar
for (int i = 1; i < 100000; i *= 2) {
System.out.println(i);
}
// Bucle for es un bucle while compactado
int cont = 0; // inicialización
while (cont < 10) { // condición
//
cont++; // modificación
}
int n = 0;
for (/* me salto la inicialización */; n < 10; n++) {
System.out.println(n);
}
n = 0;
for (/* me salto la inicialización */; n < 10; /* me salto la modificación */) {
System.out.println(n);
n++;
}
n = 0;
for (/* me salto la inicialización */; /* me salto la condición */; /* me salto la modificación */) {
System.out.println(n);
n++;
if (n >= 10) {
break;
}
}
n = 0;
for (;;) {
System.out.println(n);
n++;
if (n >= 10) {
break;
}
}
Solución ejercicios
Scanner scanner = new Scanner(System.in);
System.out.print("Introduce un número entero: ");
int a = scanner.nextInt();
System.out.print("Introduce otro número entero: ");
int b = scanner.nextInt();
System.out.println("La suma es " + (a + b));
double c = a + 7.5;
a += c;
System.out.println(a);
System.out.print("Introduce un número entero: ");
a = scanner.nextInt();
if (a % 2 == 0) {
System.out.println("Par");
} else {
System.out.println("Impar");
}
System.out.print("Introduce un número entero: ");
a = scanner.nextInt();
System.out.print("Introduce otro número entero: ");
b = scanner.nextInt();
// KISS keep it simple, stupid
int suma = 0;
while (a <= b) {
suma += a;
a++;
}
System.out.println(suma);
suma = 0;
do {
System.out.print("Introduce un número entero (0 para salir): ");
a = scanner.nextInt();
suma += a;
} while (a != 0);
System.out.format("la suma es %d",suma);
scanner.close();
Ejemplos bucle while
public class EjemplosWhile {
public static void main(String[] args) {
// Sintaxis: while(condicion){...}
int cont = 0;
// Mientras esa condición sea cierta ejecutamos el código
// que tenemos en el bucle
while (cont < 10) {
cont++; // Importantísimo modificar la condición para evitar bucles infinitos
System.out.println(cont);
}
int a = 1;
int b = 1;
int fib = a + b;
// Mientras el téermino de fibonacci sea menor que 500
while (fib < 500) {
System.out.println(fib);
a = b;
b = fib;
fib=a+b; // Modifico la condición del bucle
}
cont=10;
while(cont>0) {
System.out.println(cont);
cont--;
}
cont=0;
int suma=0;
// La suma de los 100 primeros números
while(cont<=100) {
suma+=cont;
cont++;
}
System.out.println(suma);
Scanner scanner = new Scanner(System.in);
System.out.print("Introduce un número entero: ");
int a = scanner.nextInt();
System.out.print("Introduce otro número entero: ");
int b = scanner.nextInt();
if (a>b) {
System.out.println("El primero es mayor que el segundo");
}else if (b>a){
System.out.println("El segundo es mayor que el primero");
}else {
System.out.println("Son iguales");
}
System.out.println("La tabla de multiplicar es:");
int cont=1;
while(cont<=10) {
System.out.println(a+" x "+cont+" = "+(a*cont));
cont++;
}
}
}