M3 - Programació estructurada / Exercicis UF1: D'estructura alternativa
1. Un programa demana un número. Si és parell el multiplica per dos i li suma tres. Si és senar el multiplica per tres i li resta 4. Evidentment informa de què ha fet i informa del resultat.
package estructura_alternativa;
import java.util.Scanner;
public class Exercici1 {
public static void main(String[] args) {
int numero, resultat;
Scanner lector = new Scanner(System.in);
System.out.print("Introdueix un numero: ");
numero = lector.nextInt();
if (numero % 2 == 0) {
resultat = numero * 2 + 3;
System.out.println("El numero " + numero + " es parell, l'he multiplicat per dos i li he sumat tres, i dona : " + resultat);
} else {
resultat = numero * 3 - 4;
System.out.println("El numero " + numero + " es senar, l'he multiplicat per tres i li he restat quatre, i dona : " + resultat);
}
}
}
2. Els treballadors d’una fàbrica treballen en dos torns: diürn i nocturn. Es vol calcular el salari d’un dia d’acord amb els següents punts:
- a. La tarifa de les hores diürnes és de 4€
- b. La tarifa de les hores nocturnes és de 6€
- c. En cas de ser diumenge, la tarifa s’incrementa en 2€ el torn diari i en 3€ el torn nocturn.
El programa ha de llegir les hores treballades, el torn i el dia de la setmana i dir quin serà el salari.
package estructura_alternativa;
import java.util.Scanner;
public class Exercici2 {
public static void main(String[] args) {
final int DIA = 4;
final int DIAFESTIU = 6;
final int NIT = 6;
final int NITFESTIU = 9;
Scanner lector = new Scanner(System.in);
int hores, salari;
char torn, dia;
System.out.print("Introdueix el nombre d'hores treballades: ");
hores = lector.nextInt();
System.out.print("Introdueix el torn (diari ->d/nocturn->n): ");
torn = lector.next().charAt(0);
System.out.print("Introdueix el dia (diumenge->d/feiner->f): ");
dia = lector.next().charAt(0);
if (dia == 'f') {
if (torn == 'd') {
salari = hores * DIA;
} else {
salari = hores * NIT;
}
} else if (torn == 'd') {
salari=hores*DIAFESTIU;
}
else{
salari=hores*NITFESTIU;
}
System.out.println("El salari és: "+salari);
}
}
3. Escriure un algorisme que llegeixi tres números enters i ens digui quin és el valor més gran.
package estructura_alternativa;
import java.util.Scanner;
public class Exercici3 {
public static void main(String[] args) {
Scanner lector = new Scanner(System.in);
int x,y,z,max;
System.out.print("Introdueix tres valors separats per espais: ");
x=lector.nextInt();
y=lector.nextInt();
z=lector.nextInt();
max=x;
if(y>max){
max=y;
}
if(z>max){
max=z;
}
System.out.println("El valor màxim és: " +max);
}
}
4. Escriviu un programa que simuli una calculadora simple. El programa llegeix dos enters i un caràcter. Si el caràcter és un + s’imprimeix la suma, si és un – la resta, si és un * el producte, si és un / la divisió entera i si és un %, el mòdul.
Per a poder llegir un caràcter cal fer : lector.next().charAt(0)
package estructura_alternativa;
import java.util.Scanner;
public class Exercici4 {
public static void main(String[] args) {
int resultat = 0;
Scanner teclat = new Scanner(System.in);
System.out.print("Introdueix un valor enter: ");
int numero1 = teclat.nextInt();
System.out.print("Introdueix un altre valor enter: ");
int numero2 = teclat.nextInt();
System.out.print("Introdueix l'operació a fer ( + , - , * , /, %): ");
char operacio = teclat.next().charAt(0);
if (operacio=='+') {
resultat = numero1 + numero2;
} else if (operacio=='-') {
resultat = numero1 - numero2;
} else if (operacio=='*') {
resultat = numero1 * numero2;
} else if (operacio=='/') {
resultat = numero1 / numero2;
} else if (operacio=='%') {
resultat = numero1 % numero2;
}
System.out.println("El resultat és : " + resultat);
}
}
- Utilitzant la sentencia switch:
package estructura_alternativa;
import java.util.Scanner;
public class Exercici4 {
public static void main(String[] args) {
int resultat = 0;
Scanner teclat = new Scanner(System.in);
System.out.print("Introdueix un valor enter: ");
int numero1 = teclat.nextInt();
System.out.print("Introdueix un altre valor enter: ");
int numero2 = teclat.nextInt();
System.out.print("Introdueix l'operació a fer ( + , - , * , /, %): ");
char operacio = teclat.next().charAt(0);
switch (operacio) {
case '+':
resultat = numero1 + numero2;
break;
case '-':
resultat = numero1 - numero2;
break;
case '*':
resultat = numero1 * numero2;
break;
case '/':
resultat = numero1 / numero2;
break;
case '%':
resultat = numero1 % numero2;
break;
}
System.out.println("El resultat és : " + resultat);
}
}
5. Escriviu un programa que llegeixi del teclat un enter comprès entre 0 i 63 (inclosos) i ens digui el nombre de bits que necessitem per escriure’l en binari. No s’ha de fer servir cap funció calcular-ho, sinó simplement a base de if .. else, recordant que a cada potència de 2 necessitem un bit més.
package estructura_alternativa;
import java.util.Scanner;
public class Exercici5 {
public static void main(String[] args) {
int valor, bits;
Scanner lector = new Scanner(System.in);
System.out.print("Introdueix un valor entre 0 i 64: ");
valor = lector.nextInt();
if ((valor < 0) || (valor > 64)) {
System.out.print("El valor no esta entre 0 i 64!!\n\n");
} else {
if (valor < 2) {
bits = 1;
} else if (valor < 4) {
bits = 2;
} else if (valor < 8) {
bits = 3;
} else if (valor < 16) {
bits = 4;
} else if (valor < 32) {
bits = 5;
} else {
bits = 6;
}
System.out.println("Necessitem " + bits + " bits");
}
}
}
6. Tres persones les edats de les quals s’han de llegir per teclat, van a un parc d’atraccions. El cost de l’entrada normal és de 20€. Però tenen els següents descomptes:
- A. Els menors de 5 anys no paguen però han d’anar acompanyats d’algun més gran de 12 anys, sinó no poden entrar
- B. Entre els 5 i els 12 anys paguen el 25 % de l’entrada
- C. Entre els 12 anys i els 16 anys paguen el 50 % de l’entrada
- D. Els més grans de 16 anys paguen l’entrada normal, excepte que els tres estiguin entre els 16 i els 18 anys, que aquest cas com hi ha una oferta, només pagaran dues entrades normals entre els tres.
- E. Els més grans de 65 anys no paguen
Quan costaran les tres entrades?
7. Escriviu un programa que llegeixi un mes en número i un any i indiqui el nombre de dies d’aquest mes. Cal recordar que un any és de traspàs (bixest) si és divisible per 4, excepte quan és divisible per 100, a no ser que sigui divisible per 400.
8. Per a esbrinar la Pasqua d’un any, procedirem de la següent manera:
- Dividim l’any el qual vulguem saber la Pasqua per 19 i al mòdul l’anomenem "a".
- Dividim el mateix número per 4 i anomenem al mòdul "b".
- Tornem a dividir el mateix número per 7 i anomenen al mòdul "c".
- Dividim 19*a + 24 per 30 i anomenem "d" al mòdul.
- Dividim 2*b + 4*c + 6*d + 5 per 7 i anomenem al mòdul "e".
Un cop sabut això, tenim que la Pasqua serà:
- (22 + d + e) de març (si d+e <10) o bé: (d + e - 9) d’abril .
9. Volem saber si una persona és major d’edat, per això llegirem la data de naixement i la data actual.
10. Escriure un algorisme en el qual a partir d’una data inicial llegida per teclat amb el format dia, mes, any, ens digui la data del dia següent. ( 5 punts)
Alguns exercicis més:
11. Escriu un programa que llegeixi un número enter positiu i determini si es un número de 1, 2,3 o 4 xifres.
Control d'errors: Escriu els missatges pertinents si han introduït un valor fora del rang o si han introduït una cadena de caràcters.
12. En un casino de jocs es desitja mostrar els missatges respectius per els punts obtinguts en el llançament de tres daus d'un client, d'acord als següents resultats:
- a) Si els tres daus són sis, mostrar el missatge "Excel·lent"
- b) Si dos daus són sis, mostrar el missatge "Molt bé"
- c) Si un dau és sis, mostrar el missatge "Regular"
- d) Si cap dau és sis, mostrar el missatge "Pèssim"
Utilitza per la simulació dels llançaments:
import java.util.Random; ... Random rnd = new Random(); dau1 = rnd.nextInt(6)+1;
Exemple de sortida:
Has tret: 6 6 6 Excel·lent!
13. Demaneu tres números enters positius i mostreu-los en ordre descendent.
Control d'errors: Escriu els missatges pertinents si han introduït un valor negatiu, si han introduït una cadena de caràcters o si han introduït números iguals.