Esercizi.

Slides:



Advertisements
Presentazioni simili
Oggetti Java.
Advertisements

Capitolo 8 Array Lucidi relativi al volume: Java – Guida alla programmazione James Cohoon, Jack Davidson Copyright © The McGraw-Hill Companies srl.
Programmazione Ingegneria TLC
1 Astrazioni sui dati : Specifica ed Implementazione di Tipi di Dato Astratti in Java.
LIP: 4 Aprile 2008 ECCEZIONI. Eccezioni Come si definiscono eccezioni Come si lanciano Come si gestiscono (gestione esplicita o di default)
Liste di Interi Esercitazione. Liste Concatenate Tipo di dato utile per memorizzare sequenze di elementi di dimensioni variabile Definizione tipicamente.
LIP: 19 Aprile Contenuto Soluzione Compitino Tipo di dato MultiSet, estensione con sottoclasse.
Liste Ordinate 3 Maggio Ultima Lezione Abbiamo visto i tipi di dato astratti IntList e StringList Realizzano liste di interi e di stringhe Realizzati.
LIP: 1 Marzo 2005 Classe Object e Vettori. Partiamo da Lesercizio dellultima esercitazione realizzato tramite array Vedremo come si puo fare in modo piu.
Fondamenti di Informatica
1 Corso di Laurea in Biotecnologie Informatica (Programmazione) Introduzione a JAVA Anno Accademico 2009/2010.
1 Corso di Laurea in Biotecnologie Informatica (Programmazione) Array Anno Accademico 2009/2010.
1 Corso di Informatica (Programmazione) Esercitazione 2 (3 dicembre 2008)
Specifiche senza JML: uso delle asserzioni. 2 Asserzioni in Java Dal jdk 1.4 (da Febbraio 2002) cè meccanismo per gestire asserzioni Asserzione: espressione.
1 Lezione XIII Lu 17-Nov-2005 Programmare le classi.
Scomposizione di stringhe
Algoritmi e Strutture Dati IV. Heap e Code di Priorità
Soluzione Esercizio - Classe Vettore
Gestione dei Progetti Software 2 (a.a. 2004/05) - Lezione 3 1 JAVA e Internet: il World Wide Web Internet: milioni di computer collegati fra di loro attraverso.
Selezione (=scelta) con “if-else”
Politecnico di Milano Esercizi Preparazione alla prima prova intermedia.
Programmazione in Java Claudia Raibulet
Diagramma di flusso del problema del Supermercato.
ISTITUTO STATALE DI ISTRUZIONE SUPERIORE F. ENRIQUES CORSO JAVA – PROVA INTERMEDIA DEL 12 MARZO 2007 NOME: COGNOME: ________________________________________________________________________________.
Diagramma di flusso del problema del Calcolo del Bollo di Circolazione
Programmazione concorrente
ISTITUTO STATALE DI ISTRUZIONE SUPERIORE F. ENRIQUES CORSO JAVA – PROVA INTERMEDIA DEL 12 MARZO 2007 NOME: COGNOME: ________________________________________________________________________________.
Conversione da base 10 a base X (Utilizzo della pila)
Corso di Programmazione in Java – Esercizio n° 001
Diagramma di flusso del problema dello stipendio del rappresentante.
Appunti di Java (J2SDK 1.4.2, JDK 1.6.0) prof. Antonella Schiavon settembre 2009.
Lezione n° 07 - Esercitazione
Corso di Algoritmi e Strutture Dati con Laboratorio A.A. 2014/15 Lezioni 1-2.
1 Videopoker esempio di applicazione in java. 2 Videopoker Un giocatore, con un portofaglio iniziale il giocatore punta il banco da 5 carte il giocatore.
Esercitazione Ereditarietà Polimorfismo. Entita’ Geometrica PuntoCerchioPoligono TriangoloQuadrilatero Rettangolo Quadrato.
Corso JAVA Lezione n° 10 Istituto Statale di Istruzione Superiore “F. Enriques”
Una "vera" classe.. ..un esempio pratico: la calcolatrice
Definizione di classi Capitolo 18 febbraio 2004 Definizione di classi.
Oggetti in C# Lezione 2 Metodi e Static Oggetti in C# - Lezione 2.
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica
Fondamenti di informatica Oggetti e Java Luca Cabibbo Luca Cabibbo – Fondamenti di informatica: Oggetti e Java Copyright © 2004 – The McGraw-Hill Companies.
Heap concetti ed applicazioni. maggio 2002ASD - Heap2 heap heap = catasta condizione di heap 1.albero binario perfettamente bilanciato 2.tutte le foglie.
Ereditarieta’. Contenuti Introduciamo un meccanismo fondamentale di Java: l’ereditarieta’ Permette di estendere classi gia’ definite (ovvero di definire.
Esercitazione su Vector. Permette di definire collezioni di dati generiche, che sono in grado di memorizzare elementi di ogni sottotipo di Object Definito.
AlgoLab - Pile e Code Pile e code Laboratorio di Algoritmi 02/03 Prof. Ugo de’ Liguoro.
Capitolo 6 Iterazione Lucidi relativi al volume: Java – Guida alla programmazione James Cohoon, Jack Davidson Copyright © The McGraw-Hill Companies.
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica
Gestione dei thread in Java
Liste Concatenate 11 Aprile E’ una delle strutture dati fondamentali in tutti i linguaggi di programmazione di alto livello Una Lista Concatenata.
Liste di Interi Esercitazione. IntList Lista di interi Una lista è una disposizione ordinata di elementi ( non in modo crescente-descrescente, ma per.
1 Gerarchie e polimorfismo: liste. 2 Generalizzare le liste di interi  List 4 lista di oggetti –non modificabile 4 vorremo poi definire un sottotipo.
Public class SimpleHash { //DICHIARAZIONE DELLE VARIABILI DI ISTANZA //tabella hash private int[] table; //dimensione della tabella (meglio se numero primo)
Ese 3 (del 3 Aprile 2003). Testo Progettare la specifica e l’implementazione del tipo di dato astratto modificabile Stack, supponendo che gli elementi.
Esercitazione del 7 marzo 2008 Ereditarieta’. Esercizio: soluzione Implementare la seguente specifica che definisce un tipo di dato Libro.
Ese 3 (del 3 Aprile 2003). Testo Progettare la specifica e l’implementazione del tipo di dato astratto modificabile Stack, supponendo che gli elementi.
Esercizio 3. Testo Dare rappresentazione e realizzazione dei metodi della seguente classe QueueWithPriority. Nella risposta, non riportare i commenti.
LIP: 2 Maggio 2008 Classi Astratte. Cos’e’ una Classe Astratta una classe astratta e’ un particolare tipo di classe permette di fornire una implementazione.
Sommario Oggetti immutabili e non Tipi Primitivi: String, Arrays.
Ese 1 e 3 (del 6 Aprile 2005). Primo Ese Si identifichino gli errori che il compilatore segnalerebbe per il seguente programma Tipi Legami tra dichiarazioni.
LIP: 11 Maggio 2007 Classi Astratte. Cos’e’ una Classe Astratta una classe astratta e’ un particolare tipo di classe permette di fornire una implementazione.
Esercitazione 14 Marzo Esercizio dell’altra volta Definire un tipo di dato Abbonato i cui oggetti descrivono le informazioni relative ad un abbonato.
Esercitazione del 9 marzo 2007 Ereditarieta’. Richiami Definire sottoclassi (ereditarieta’) Overriding Specificatori di accesso (private, protected) Principio.
Liste Concatenate 28 Marzo Avviso Martedi’ 4 Aprile: Verifica di LIP Per iscriversi (obbligatorio) inviare un e- mail entro venerdi’ 31 Marzo a.
Esercitazione sull’ ordinamento 20 maggio 2003
LIP: 4 Maggio 2007 Interfacce. Cos’e’ una Interfaccia una interfaccia e’ un particolare tipo di classe contiene solo la specifica non ha implementazione.
LIP: 15 Marzo 2005 Vettori di interi. Esercizio proposto Definire una classe VectorInt i cui oggetti sono vettori omogenei di interi ordinati in modo.
LIP: 18 Aprile 2008 Interfacce. Rappresentazione Lista val next vuota Lista vuota: any true Lista non vuota: any true 154 false 24 false.
Ex.1 - Astrazioni su Dati Si abbia il tipo di dato stack di interi, IntStack, specificato sotto: public class IntStack { \\ OVERVIEW: uno Stack è una collezione.
Stringhe in Java. Definire una stringa. Definire una stringa in Java Il modo più semplice e diretto per creare un oggetto di tipo String è assegnare alla.
Condizioni decisionali e costrutto if. 2 Operatori relazionali e logici = Maggiore, maggiore uguale ==, != Uguale a, diverso.
Transcript della presentazione:

Esercizi

Esercizio Si scriva un insieme di classi per i poligoni nel piano. Ogni poligono è costituito da una successione di punti, ognuno descritto tramite le sue coordinate cartesiane. Per ogni poligono deve essere possibile calcolare il perimetro.

class Point { float x,y; //Questo e' il costruttore Point(float x, float y) { this.x = x; this.y = y; } //Restituisce la distanza tra this e un altro punto public float distance(Point p) { return Math.sqrt( (this.x - p.x)*(this.x - p.x) + (this.y - p.y)*(this.y - p.y) ); }

class Polygon { Point[] vertices; Polygon(int nvertices) { vertices = new Point[nvertices]; } void setVertex(int n, float x, float y) {vertici[n-1] = new Point(x,y); } public float perimeter() { float p = 0; for (int i = 0; i < vertices.length - 1; i++) p += vertices[i].distance(vertices[i + 1]); p += vertices[vertices.length - 1].distance(vertices[0]); return p; }

Set Definire una classe per gestire un Set (collezione di oggetti non ordinata senza ripetizioni) di interi class Set { private int numbers[]; private int cur_size;

Costruttori – soluzione brutta public Set(int dimensione) { cur_size=0; numbers = new int[dimensione]; } public Set() { int dimensione=100; //dimensione di default

Costruttori public Set(int dimensione) { cur_size=0; numbers = new int[dimensione]; } public Set() { this(100); //dimensione di default

public boolean isMember(int n) { int i=0; while(i < cur_size) if(numbers[i]==n) return true; i++; } return false;

public void addMember(int n) { if(isMember(n)) return; if(cur_size == numbers.length) return; numbers[cur_size] = n; cur_size++; }

public void deleteMember(int n) { int i=0; while(i < cur_size) { if(numbers[i]==n) { cur_size--;  numbers[i]=numbers[i+1]; i++; } return; }  

public void showSet() { int i=0; boolean first=true; String s=new String(“{“); while(i < cur_size) { //per non mettere virgole prima del primo elemento if(first) first=false; else s+=" , "; s+=numbers[i]; i++; } s+="}"; System.out.println(s);

//main di test public static void main(String args[]) { Set s=new Set(100); System.out.println("Inserisco 1"); s.addMember(1); System.out.println("Inserisco 7"); s.addMember(7); System.out.println("Inserisco 9"); s.addMember(9); System.out.println("Inserisco 11"); s.addMember(11); System.out.println("Mostro il contenuto del set"); s.showSet(); System.out.println("Elimino il 7"); s.deleteMember(7); }

Stack Definire una classe per gestire una Stack di interi

Stack class Stack { int data[]; int first; int max; Stack(int dimensione) { data=new int[dimensione]; first=0; max=dimensione; } Stack() { this(10); }

int pop() { if (first > 0) { first--; return data[first]; } return -10000; // Bisogna restituire qualcosa void push(int i) { if (first < max) { data[first] = i; first++;

//main di test public static void main(String args[]) { Stack s=new Stack(5); System.out.println("Inserisco 1"); s.push(1); System.out.println("Inserisco 7"); s.push(7); System.out.println("Estraggo un elemento: "+s.pop()); }

Cantanti – per gara canora public class Singer { private String cognome; private String nome; private String dataDiNascita; private String luogoDiNascita; private String canzone;

Getter e setter /*** @return Returns the cognome. */ public String getCognome() { return cognome; } /*** @param cognome The cognome to set. */ public void setCognome(String cognome) { this.cognome = cognome; …

public Singer(String cognome, String nome, String dataDiNascita, String luogoDiNascita, String canzone) { this.cognome = cognome; this.nome = nome; this.dataDiNascita = dataDiNascita; this.luogoDiNascita = luogoDiNascita; this.canzone = canzone; } /*** default constructor */ public Singer() { }

public String toString() { return cognome+" "+nome; } public boolean equals(Singer s) { return cognome.equals(s.getCognome()) && nome.equals(s.getNome()) && canzone.equals(s.getCanzone()) && dataDiNascita.equals(s.getDataDiNascita())&& luogoDiNascita.equals(s.getLuogoDiNascita());

public int compareTo(Singer s) { int n=cognome.compareTo(s.getCognome()); if(n==0) n=nome.compareTo(s.getNome()); return n; } public boolean minoreDi(Singer s) { return (compareTo(s) < 0);

Competition public class Competition { private static final int numCantanti = 10; private String denominazione; private String luogo; private String nomePresentatore; private String dataInizio; private String dataFine; private Singer[] classifica; private int indiceCantanti;

public Competition(String denominazione, String luogo, String nomePresentatore, String dataInizio, String dataFine) { this.denominazione = denominazione; this.luogo = luogo; this.nomePresentatore = nomePresentatore; this.dataInizio = dataInizio; this.dataFine = dataFine; indiceCantanti=0; classifica=new Singer[numCantanti]; }

public String toString() { return denominazione+" a "+luogo +" presentata da "+nomePresentatore +" dal "+dataInizio+" al "+dataFine; } public void print() { System.out.println(this);

/** aggiunge il cantante nella posizione */ public void addSinger(Singer s,int posizione) { int pos=posizione-1; for(int i=numCantanti-1;i>pos;i--) { classifica[i]=classifica[i-1]; } classifica[pos]=s; if(indiceCantanti<numCantanti-1) indiceCantanti++;

/** aggiunge il cantante nella prima posizione libera */ public void addSinger(Singer s) { if(indiceCantanti<numCantanti-1) classifica[indiceCantanti]=s; indiceCantanti++; }

/* * cerca il cantante */ public Singer findSinger(String cognome,String nome) { for(int i=0;i<indiceCantanti;i++) { if(classifica[i].getCognome().equals(cognome) && classifica[i].getNome().equals(nome)) return classifica[i]; } return null;

public void deleteSinger(Singer s) { for(int i=0;i<indiceCantanti;i++) { if(classifica[i].equals(s)) for(int j=i;j<indiceCantanti-1;j++) classifica[j]=classifica[j+1]; } classifica[indiceCantanti]=new Singer(); indiceCantanti--;

public void deleteSinger(String cognome,String nome) { deleteSinger(findSinger(cognome,nome)); } public String generaClassifica() { String str=toString(); for(int i=0;i<indiceCantanti;i++) str+="\n"+classifica[i]; //viene chiamato toString() return str;

public void stampaClassifica() { System.out.println(generaClassifica()); } public String generaListaOrdinata() { Singer[] ordinati=new Singer[numCantanti]; for(int i=0;i<indiceCantanti;i++) { ordinati[i]=classifica[i]; Continua…

for(int i=0;i<indiceCantanti-1;i++) { for(int j=0;j<indiceCantanti-1;j++) { if(ordinati[j+1].minoreDi(ordinati[j])) { Singer temp=ordinati[j+1]; ordinati[j+1]=ordinati[j]; ordinati[j]=temp; } String str=toString(); for(int i=0;i<indiceCantanti;i++) str+="\n"+ordinati[i]; return str;

Illustrare l'effetto dei seguenti programmi sullo stack e sullo heap. class Example1 { public static void main(String args[]) { String s1 = "abc"; String s2 = "abc"; String s3 = new String("abc"); String s4 = s3; }

Risposta: 1- s1 e s2 puntano allo stesso oggetto stringa nello heap, s3 punta ad un oggetto diverso nello heap, al quale punta anche s4: s1 -> "abc" <- s2 s3 -> "abc" <- s4

Esercizio Illustrare l'effetto dei seguenti programmi sullo stack e sullo heap. class Example2 { int x; public static void main(String args[]) { float a[] = new float[3]; String b[] = new String[3]; String y; }

2- a punta ad un array contenente tre float nello heap (tutti e tre inizializzati a zero), b punta ad un array nello heap contenente tre reference impostati a null, x contiene 0, y contiene null. a -> [0.0 0.0 0.0] b -> [null null null] x: 0 y: null Notare che x viene inizializzata dal costruttore (ogni classe ha un costruttore di default). Se x fosse stata dichiarata come variabile locale del metodo main, il compilatore avrebbe lamentato l'assenza di una inizializzazione per x.

Esercizio Consideriamo una ipotetica implementazione in C, o in un qualsiasi linguaggio procedurale, di un tipo di dato qualsiasi, ad esempio per i punti nello spazio: /* un nuovo tipo per la struttura dati */ typedef struct { float x,y; } *planepoint; /* le operazioni che manipolano le variabili di tipo planepoint */ void init(planepoint *this, float x, float y) {this->x =x; this->y = y;} void translate(planepoint *this, float deltax, float deltay) ... float distance(planepoint *this, planepoint *another) ... Ridefinirlo in Java

Tutte e tre le operazioni, per definizione, compiono una azione su una variabile di tipo planepoint, e quindi hanno *almeno* un parametro di tale tipo. In Java questo fatto e' messo in evidenza richiedendo che le dichiarazioni delle funzioni vengano messe *dentro* alla dichiarazione del tipo: /* dichiarazione del tipo E delle operazioni che manipolano le sue variabili */ class PlanePoint { /* i dati di un oggetto di tipo PlanePoint */ float x,y; /* le operazioni che lo manipolano */ PlanePoint(float x, float y) { this.x = x; this.y = y; } //questa sostituisce la init void translate(float deltax, float deltay) ... float distance(PlanePoint another) ... }

Le principali differenze sono: il parametro this viene automaticamente passato da Java alle tre operazioni, e quindi NON va dichiarato (non c'e' bisogno!) l'operazione che inizializza un nuovo oggetto di tipo PlanePoint ha lo stesso nome del tipo, e viene AUTOMATICAMENTE invocata da Java non appena viene creato l'oggetto: in questo modo l'oggetto è sempre in uno stato consistente. L'operazione viene detta *costruttore*

Scrivere una classe per definire numeri complessi class complesso { private double reale, immaginaria; public complesso(double i,double j) { reale=i; immaginaria=j; }

public double reale() { return reale; } public double immaginaria() { return immaginaria;

public double modulo() { return Math.sqrt(this.reale*this.reale+ this.immaginaria*this.immaginaria); } public double fase() { if(this.reale==0) return Math.PI/2;//se reale=0 fase=90 gradi else return Math.atan(this.immaginaria/this.reale); //se non conoscete atan non importa ;

public complesso somma(complesso altro) { return new complesso(this.reale+altro.reale, this.immaginaria+altro.immaginaria); } public complesso differenza(complesso altro) { return new complesso(this.reale-altro.reale, this.immaginaria-altro.immaginaria); public complesso prodotto(complesso altro) { return new complesso(this.reale*altro.reale- this.immaginaria*altro.immaginaria, this.reale*altro.immaginaria+ this.immaginaria*altro.reale);

public String toString() { return ""+reale+"+"+immaginaria+"i"; } public static void main(String args[]) { complesso a=new complesso(5,6); complesso b=new complesso(4,0); complesso c=a.somma(b); complesso d=a.differenza(b); complesso e=a.prodotto(b); double m=a.modulo(); double f=a.fase(); System.out.println(a); System.out.println(b); System.out.println(c); System.out.println(d); System.out.println(e); System.out.println(m); System.out.println(f);