Capitolo 7 array e array list
|
|
- Giuditta Coco
- 6 anni fa
- Visualizzazioni
Transcript
1 Capitolo 7 array e array list Obiettivi del capitolo Acquisire familiarità con l utilizzo di array e array list (vettori ) Studiare le classi involucro, la tecnica di autoimpacchettamento e il ciclo for generalizzato Apprendere gli algoritmi più comuni per gli array Capire come usare array bidimensionali Imparare a scegliere array o vettori nei vostri programmi Realizzare array riempiti solo in parte Fondamenti Informatica UNIPD Array Array Sequenza di valori dello stesso tipo Costruisci un array: new double[10] Memorizza in variabile del tipo double[ ] double[] data = new double[10]; Quando un array viene creato, tutti i valori vengono inizializzati in base al tipo dell array: Numeri: 0 Boolean: false Riferimenti agli oggetti: null Continued Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
2 Array Si usa [ ] per accedere ad un elemento data[2] = 29.95; DieTester.java 01: /** 02: Questo programma registra dieci lanci di un dado. 03: */ 04: public class DieTester 05: { 06: public static void main(string[] args) 07: { 08: final int TRIES = 10; 09: Die d = new Die(6); int[] lanci = new int[tries]; 10: for (int i = 0; i < TRIES; i++) { 12: lanci[i] = d.cast(); 14: 15: System.out.println(lanci); 16: 17: Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Array Array Per utilizzare il valore memorizzato: System.out.println("The data item is " + data[4]); Si ricava la lunghezza dell array con data.length. (Non è un metodo!) Il valore dell indice deve essere compreso fra 0 e length - 1 Accedere ad un elemento non esistente è un errore double[] data = new double[10]; data[10] = 29.95; // ERROR Limitazione: gli array hanno una lunghezza fissa Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
3 Sintassi 8.1: Costruzione di Array Sintassi 8.2: Accesso a Elementi di Array new nometipo [lunghezza] Esempio: new double[10] Obiettivo: Costruire un array con un dato numero di elementi riferimentoadarray [Indice] Esempio: data[2] Obiettivo: Accedere ad un elemento diun array Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Verifica Verifica 1. Quali valori sono presenti nell array dopo l esecuzione dei seguenti enunciati? double[] data = new double[10]; for (int i = 0; i < data.length; i++) data[i] = i * i; 2. Cosa visualizzano i seguenti frammenti di programma? Oppure, se c è un errore, descrivete l errore ed indicate se si tratta di un errore di compilazione o di un errore di esecuzione. 1. double[] a = new double[10]; System.out.println(a[0]); 2. double[] b = new double[10]; System.out.println(b[10]); 3. double[] c; System.out.println(c[0]); Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
4 Risposte Array bidimensionali 1. 0, 1, 4, 9, 16, 25, 36, 49, 64, 81, ma non Errore di esecuzione: indice di array fuori dai limiti 3. Errore di compilazione: c non è inizializzata Fondamenti Informatica UNIPD Costruendo un array bidimensionale, specificate di quante righe o colonne avete bisogno: final int ROWS = 3; final int COLUMNS = 3; String[][] board = new String[ROWS][COLUMNS]; Accedete ad elementi con una coppia di indici a[i][j] board[i][j] = "x"; Fondamenti Informatica UNIPD Una scacchiera Tic Tac Toe Attraversare array bidimensionali Di solito si usano cicli annidati quando si inseriscono o si cercano dati: for (int i = 0; i < ROWS; i++) for (int j = 0; j < COLUMNS; j++) board[i][j] = " "; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
5 File TicTacToe.java 01: /** 02: A 3 x 3 tic-tac-toe board. 03: */ 04: public class TicTacToe 05: { 06: /** 07: Constructs an empty board. 08: */ 09: public TicTacToe() 10: { 11: board = new String[ROWS][COLUMNS]; 12: // Fill with spaces 13: for (int i = 0; i < ROWS; i++) 14: for (int j = 0; j < COLUMNS; j++) 15: board[i][j] = " "; 16: 17: Segue Fondamenti Informatica UNIPD File TicTacToe.java 18: /** 19: Sets a field in the board. The field must be unoccupied. i the row index j the column index player the player ("x" or "o") 23: */ 24: public void set(int i, int j, String player) 25: { 26: if (board[i][j].equals(" ")) 27: board[i][j] = player; 28: 29: 30: /** 31: Creates a string representation of the board, such as 32: x o 33: x 34: o the string representation 36: */ Segue Fondamenti Informatica UNIPD File TicTacToe.java 37: public String tostring() 38: { 39: String r = ""; 40: for (int i = 0; i < ROWS; i++) 41: { 42: r = r + " "; 43: for (int j = 0; j < COLUMNS; j++) 44: r = r + board[i][j]; 45: r = r + " \n"; 46: 47: return r; 48: 49: 50: private String[][] board; 51: private static final int ROWS = 3; 52: private static final int COLUMNS = 3; 53: Fondamenti Informatica UNIPD File TicTacToeTester.java 01: import java.util.scanner; 02: 03: /** 04: This program tests the TicTacToe class by prompting the 05: user to set positions on the board and printing out the 06: result. 07: */ 08: public class TicTacToeTester 09: { 10: public static void main(string[] args) 11: { 12: Scanner in = new Scanner(System.in); 13: String player = "x"; 14: TicTacToe game = new TicTacToe(); 15: boolean done = false; 16: while (!done) 17: { Segue Fondamenti Informatica UNIPD
6 File TicTacToeTester.java 18: System.out.print(game.toString()); 19: System.out.print( 20: "Row for " + player + " (-1 to exit): "); 21: int row = in.nextint(); 22: if (row < 0) done = true; 23: else 24: { 25: System.out.print("Column for " + player + ": "); 26: int column = in.nextint(); 27: game.set(row, column, player); 28: if (player.equals("x")) 29: player = "o"; 30: else 31: player = "x"; 32: 33: 34: 35: Segue Fondamenti Informatica UNIPD Output Row for x (-1 to exit): 1 Column for x: 2 x Row for o (-1 to exit): 0 Column for o: 0 o x Row for x (-1 to exit): -1 Fondamenti Informatica UNIPD Verifica Risposte 11. Come si dichiara e si inizializza un array di interi 4 per 4? 12. Come si conta il numero di caselle non occupate nella scacchiera tic-tac-toe? int[][] array = new int[4][4]; int count = 0; for (int i = 0; i < ROWS; i++) for (int j = 0; j < COLUMNS; j++) if (board[i][j] == ' ') count++; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
7 Copiare Array: Copiare riferimenti agli array Copiare Array: Copiare riferimenti agli array Copiando una variabile array otterrete un altro riferimento allo stesso array double[] data = new double[10]; // fill array... double[] prices = data; Segue Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Copiare = Clonare array Copiare = Clonare array Usate clone per fare una vera copia double[] prices = (double[]) data.clone(); Segue Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
8 Copiare Array: Copiare elementi array Aggiungere un elemento ad un array System.arraycopy(from, fromstart, to, tostart, count); System.arraycopy(data, i, data, i + 1, data.length - i - 1); data[i] = x; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Rimuovere un elemento da un array Ingrandire un array System.arraycopy(data, i + 1, data, i, data.length - i - 1); Se l array è pieno e avete bisogno di più spazio, potete ingrandirlo: 1. Creare un nuovo array più grande. double[] newdata = new double[2 * data.length]; 2. Copiare tutti gli elementi nel nuovo array System.arraycopy(data, 0, newdata, 0, data.length); 3. Salvare il riferimento al nuovo array nella variabile array data = newdata; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
9 Ingrandire un array Verifica 13. Come si aggiungono o si eliminano elementi in una posizione intermedia di un vettore? 14. Perché, quando non c è più spazio in un array, ne raddoppiamo la dimensione invece di aumentarla di un unità? Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Risposte Trasformare array paralleli in array di oggetti 13. Usate I metodi insert e remove. 14. Perché è uno spreco di tempo, bisognerebbe ripetere il processo ogni volta che si aggiunge un elemento. // Don't do this int[] accountnumbers; double[] balances; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
10 Trasformare array paralleli in array di oggetti Evitate array paralleli array di oggetti: BankAccount[] = accounts; Fondamenti Informatica UNIPD Array riempiti solo in parte Lunghezza di un array = numero massimo di elementi in un array Di solito è riempito solo in parte Necessita di una variabile associata per tenere traccia della dimensione corrente Uniformate I nomi: final int DATA_LENGTH = 100; double[] data = new double[data_length]; int datasize = 0; Segue Fondamenti Informatica UNIPD Array riempiti solo in parte Array riempiti solo in parte Aggiornate datasize quando l array è pieno: data[datasize] = x; datasize++; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
11 Buffer over-run Vettori La classe ArrayList controlla una serie di oggetti Può crescere e restringersi in base alle necessità La classe ArrayList fornisce metodi per svolgere le operazioni più comuni, come l inserimento o la rimozione di elementi Continued Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Vettori Ricavare elementi di un vettore La classe ArrayList è una classe generica: ArrayList<T> contiene oggetti del tipo T: ArrayList<BankAccount> accounts = new ArrayList<BankAccount>(); accounts.add(new BankAccount(1001)); accounts.add(new BankAccount(1015)); accounts.add(new BankAccount(1022)); Si usa il metodo get L indice parte da 0 BankAccount anaccount = accounts.get(2); // ricava il terzo elemento di un vettore Se l indice è fuori dai valori, risulta un errore di limiti Il metodo size restituisce la dimensione attuale di un vettore Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
12 Ricavare elementi di un vettore Errori di limiti più comuni: int i = accounts.size(); anaccount = accounts.get(i); // Error // legal index values are 0...i-1 Fondamenti Informatica UNIPD Aggiungere e rimuovere elementi set sovrascrive un elemento esistente BankAccount anaccount = new BankAccount(1729); accounts.set(2, anaccount); add aggiunge un nuovo valore nella posizione indicata accounts.add(i, a) remove rimuove l elemento nella posizione indicata Accounts.remove(i) Continued Fondamenti Informatica UNIPD Aggiungere e rimuovere elementi File: ArrayListTester.java 01: import java.util.arraylist; 02: 03: /** 04: This program tests the ArrayList class. 05: */ 06: public class ArrayListTester 07: { 08: public static void main(string[] args) 09: { 10: ArrayList<BankAccount> accounts 11: = new ArrayList<BankAccount>(); 12: accounts.add(new BankAccount(1001)); 13: accounts.add(new BankAccount(1015)); 14: accounts.add(new BankAccount(1729)); 15: accounts.add(1, new BankAccount(1008)); 16: accounts.remove(0); jcreator Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
13 File: ArrayListTester.java 17: 18: System.out.println("size=" + accounts.size()); 19: BankAccount first = accounts.get(0); 20: System.out.println("first account number=" 21: + first.getaccountnumber()); 22: BankAccount last = accounts.get(accounts.size() - 1); 23: System.out.println("last account number=" 24: + last.getaccountnumber()); 25: 26: File: BankAccount.java 01: /** 02: A bank account has a balance that can be changed by 03: deposits and withdrawals. 04: */ 05: public class BankAccount 06: { 07: /** 08: Constructs a bank account with a zero balance anaccountnumber the account number for this account 10: */ 11: public BankAccount(int anaccountnumber) 12: { 13: accountnumber = anaccountnumber; 14: balance = 0; 15: 16: Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD File: BankAccount.java 17: /** 18: Constructs a bank account with a given balance anaccountnumber the account number for this account initialbalance the initial balance 21: */ 22: public BankAccount(int anaccountnumber, double initialbalance) 23: { 24: accountnumber = anaccountnumber; 25: balance = initialbalance; 26: 27: 28: /** 29: Gets the account number of this bank account. the account number 31: */ 32: public int getaccountnumber() 33: { 34: return accountnumber; 35: Continued Fondamenti Informatica UNIPD File: BankAccount.java 36: 37: /** 38: Deposits money into the bank account. amount the amount to deposit 40: */ 41: public void deposit(double amount) 42: { 43: double newbalance = balance + amount; 44: balance = newbalance; 45: 46: 47: /** 48: Withdraws money from the bank account. amount the amount to withdraw 50: */ 51: public void withdraw(double amount) 52: { 53: double newbalance = balance - amount; 54: balance = newbalance; Continued Fondamenti Informatica UNIPD
14 File: BankAccount.java 55: 56: 57: /** 58: Gets the current balance of the bank account. the current balance 60: */ 61: public double getbalance() 62: { 63: return balance; 64: 65: 66: private int accountnumber; 67: private double balance; 68: Output size=3 first account number=1008 last account number=1729 Fondamenti Informatica UNIPD Verifica 3. Come si costruisce un array di 10 stringhe? E un vettore di stringhe? 4. Cosa contiene names dopo l esecuzione dei seguenti enunciati? ArrayList<String> names = new ArrayList<String>(); names.add("a"); names.add(0, "B"); names.add("c"); names.remove(1); Fondamenti Informatica UNIPD Risposte Involucri 3. new String[10]; new ArrayList<String>(); 4. names contiene le stringhe "B" e "C" alle posizioni 0 e 1 Non si possono inserire tipi primitivi direttamente in vettori, devono essere trasformati in oggetti classi involucro ArrayList<Double> data = new ArrayList<Double>(); data.add(29.95); double x = data.get(0); Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
15 Involucri Auto-impacchettamento classi involucro per tutti i tipi primitivi Auto-impacchettamento: a partire da Java 5.0, la conversione tra tipi primitivi e le corrispondenti classi involucro è automatica Double d = 29.95; // auto-boxing; same as // Double d = new Double(29.95); double x = d; // auto-unboxing; same as // double x = d.doublevalue(); Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Auto-impacchettamento L auto-impacchettamento lavora anche all interno di espressioni aritmetiche Double e = d + 1; Significati: Converti d in un valore di tipo double Aggiungi 1 Impacchetta il risultato in un nuovo oggetto di tipo Double Memorizza in e il riferimento all oggetto involucro appena creato Fondamenti Informatica UNIPD Verifica 5. Qual è la differenza fra i tipi double e Double? 6. Se data è un esemplare di ArrayList<Double> con dimensione maggiore di zero, come si aggiunge un unità al valore memorizzato nell elemento di indice zero? Fondamenti Informatica UNIPD
16 Risposte Il ciclo for generalizzato 5. double è uno degli otto tipi primitivi. Double è un tipo di classe. 6. data.set(0, data.get(0) + 1); double[] data =...; double sum = 0; for (double e : data) { sum = sum + e; double[] data =...; double sum = 0; for (int i = 0; i < data.length; i++) { double e = data[i]; sum = sum + e; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Il ciclo for generalizzato Il ciclo for generalizzato Funziona anche per ArrayLists : ArrayList<BankAccount> accounts =... ; double sum = 0; for (BankAccount a : accounts) { sum = sum + a.getbalance(); E equivalente al seguente ciclo for ordinario: double sum = 0; for (int i = 0; i < accounts.size(); i++) { BankAccount a = accounts.get(i); sum = sum + a.getbalance(); Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
17 Sintassi 8.3: Il ciclo for generalizzato Verifica for (Type variable : collection) statement Esempio: for (double e : data) sum = sum + e; Obiettivo: Eseguire un ciclo avente un iterazione per ogni elemento appartenente ad una raccolta. All inizio di ciascuna iterazione viene assegnato alla variabile l elemento successivo della raccolta, poi viene eseguito l enunciato. 7. Scrivi un ciclo for generalizzato che visualizzi tutti gli elementi dell array data 8. Perchè non è ragionevole utilizzare un ciclo for generalizzato al posto del seguente ciclo ordinario? for (int i = 0; i < data.length; i++) data[i] = i * i; Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD Risposte for (double x : data) System.out.println(x); 8. Il ciclo scrive un valore data[i]. Il ciclo for non ha l indice variabile i. Fondamenti Informatica UNIPD Semplici algoritmi per vettori: contare occorrenze di un valore Controlla tutti gli elementi e conta le occorrenze di un valore fino alla fine dell array public class Bank { public int count(double atleast) { int matches = 0; for (BankAccount a : accounts) { if (a.getbalance() >= atleast) matches++; // Found a match return matches;... private ArrayList<BankAccount> accounts; Fondamenti Informatica UNIPD
18 Semplici algoritmi per vettori: Trovare un valore Semplici algoritmi per vettori : Trovare il massimo o il minimo Controllate tutti gli elementi finché trovate un valore. public class Bank { public BankAccount find(int accountnumber){ for (BankAccount a : accounts) { // Found a match if (a.getaccountnumber() == accountnumber) return a; return null; // No match in the entire array list private ArrayList<BankAccount> accounts; Fondamenti Informatica UNIPD Scegliete un candidato come valore massimo Confrontate il candidato con gli altri elementi Sostituitelo se trovate un valore maggiore o minore Segue Fondamenti Informatica UNIPD Semplici algoritmi per vettori : Trovare il massimo o il minimo Semplici algoritmi per vettori : Trovare il massimo o il minimo Esempio: BankAccount largestyet = accounts.get(0); for (int i = 1; i < accounts.size(); i++) { BankAccount a = accounts.get(i); if (a.getbalance() > largestyet.getbalance()) largestyet = a; return largestyet; Funziona solo se c è almeno un elemento nella lista degli array Se la lista è vuota, il metodo restituisce null if (accounts.size() == 0) return null; BankAccount largestyet = accounts.get(0);... Fondamenti Informatica UNIPD Fondamenti Informatica UNIPD
19 File Bank.java 01: import java.util.arraylist; 02: 03: /** 04: This bank contains a collection of bank accounts. 05: */ 06: public class Bank 07: { 08: /** 09: Constructs a bank with no bank accounts. 10: */ 11: public Bank() 12: { 13: accounts = new ArrayList<BankAccount>(); 14: 15: 16: /** 17: Adds an account to this bank. jcreator a the account to add 19: */ Segue Fondamenti Informatica UNIPD File Bank.java 20: public void addaccount(bankaccount a) 21: { 22: accounts.add(a); 23: 24: 25: /** 26: Gets the sum of the balances of all accounts in this bank. the sum of the balances 28: */ 29: public double gettotalbalance() 30: { 31: double total = 0; 32: for (BankAccount a : accounts) 33: { 34: total = total + a.getbalance(); 35: 36: return total; 37: 38: Segue Fondamenti Informatica UNIPD File Bank.java File Bank.java 39: /** 40: Counts the number of bank accounts whose balance is at 41: least a given value. atleast the balance required to count an account the number of accounts having least the given // balance 44: */ 45: public int count(double atleast) 46: { 47: int matches = 0; 48: for (BankAccount a : accounts) 49: { 50: if (a.getbalance() >= atleast) matches++; // Found // a match 51: 52: return matches; 53: Segue 54: Fondamenti Informatica UNIPD : /** 56: Finds a bank account with a given number. accountnumber the number to find the account with the given number, or null 59: if there is no such account 60: */ 61: public BankAccount find(int accountnumber) 62: { 63: for (BankAccount a : accounts) 64: { 65: if (a.getaccountnumber() == accountnumber) // Found a match 66: return a; 67: 68: return null; // No match in the entire array list 69: 70: Segue Fondamenti Informatica UNIPD
20 File Bank.java 71: /** 72: Gets the bank account with the largest balance. the account with the largest balance, or 74: null if the bank has no accounts 75: */ 76: public BankAccount getmaximum() 77: { 78: if (accounts.size() == 0) return null; 79: BankAccount largestyet = accounts.get(0); : for (int i = 1; i < accounts.size(); i++) 81: { 82: BankAccount a = accounts.get(i); 83: if (a.getbalance() > largestyet.getbalance()) 84: largestyet = a; 85: 86: return largestyet; 87: 88: 89: Fondamenti private ArrayList<BankAccount> accounts; Informatica UNIPD : File BankTester.java 01: /** 02: This program tests the Bank class. 03: */ 04: public class BankTester 05: { 06: public static void main(string[] args) 07: { 08: Bank firstbankofjava = new Bank(); 09: firstbankofjava.addaccount(new BankAccount(1001, 20000)); 10: firstbankofjava.addaccount(new BankAccount(1015, 10000)); 11: firstbankofjava.addaccount(new BankAccount(1729, 15000)); 12: 13: double threshold = 15000; 14: int c = firstbankofjava.count(threshold); 15: System.out.println(c + " accounts with balance >= " + threshold); Segue Fondamenti Informatica UNIPD File BankTester.java File BankTester.java 16: 17: int accountnumber = 1015; 18: BankAccount a = firstbankofjava.find(accountnumber); 19: if (a == null) 20: System.out.println("No account with number " + accountnumber); 21: else 22: System.out.println("Account with number " + accountnumber 23: + " has balance " + a.getbalance()); 24: 25: BankAccount max = firstbankofjava.getmaximum(); 26: System.out.println("Account with number " 27: + max.getaccountnumber() 28: + " has the largest balance."); 29: 30: Segue Fondamenti Informatica UNIPD Output 2 accounts with balance >= Account with number 1015 has balance Account with number 1001 has the largest balance. Fondamenti Informatica UNIPD
21 Verifica Risposte 9. Come si comporta il metodo find se esistono due conti bancari con il numero di conto uguale al numero cercato? 10. Si potrebbe usare il ciclo "for" generalizzato nel metodo getmaximum? 9. Restituisce il primo che trova 10. Sì, ma il primo confronto fallirà sempre Fondamenti Informatica UNIPD 2007 Fondamenti Informatica UNIPD
Capitolo 7 Vettori e array. Cay S. Horstmann Concetti di informatica e fondamenti di Java quarta edizione
Capitolo 7 Vettori e array Cay S. Horstmann Concetti di informatica e fondamenti di Java quarta edizione Obiettivi del capitolo Acquisire familiarità con l utilizzo di array e vettori Studiare le classi
DettagliCollezione di oggetti: Array List
Vettori e Array Collezione di oggetti: Array List La classe Purse non tiene traccia deisingoli oggetti di tipo Coin, ma memorizza solo il valore totale Possiamo memorizzare una collezione di oggetti mediante
DettagliLivelli di astrazione
Realizzare Classi Astrazione Perdita di dettaglio Utile nella descrizione, progettazione, implementazione e utilizzo di sistemi complessi Dettagli trascurabili vengono incapsulati in sottosistemi più semplici
Dettagli18 - Vettori. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo
18 - Vettori Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://pages.di.unipi.it/milazzo milazzo di.unipi.it Corso di
DettagliParcheggio.rtf 1/8 6 gennaio 2009. Prova di programmazione: parcheggio a pagamento
Parcheggio.rtf 1/8 6 gennaio 2009 Prova di programmazione: parcheggio a pagamento Si sviluppi il codice per la gestione di un parcheggio a pagamento mediante la classe Parcheggio, che ospita le auto rappresentate
DettagliARRAY BIDIMENSIONALI float [][] mx = new float[3][4]; (float []) [] mx = new float[3][4];
ARRAY BIDIMENSIONALI Si possono definire array di qualunque tipo di dato, quindi anche di altre array float [][] mx = new float[3][4]; ovvero.. (float []) [] mx = new float[3][4]; La loro motivazione (storica)
DettagliEsercizio 6 Realizzare una classe astratta per le Figure piane e due sottoclassi, la sottoclasse Quadrato e la sottoclasse Rettangolo.
Esercizio 6 Realizzare una classe astratta per le Figure piane e due sottoclassi, la sottoclasse Quadrato e la sottoclasse Rettangolo. public abstract class FiguraPiana2{ private double base; public FiguraPiana2(double
DettagliEsercitazioni aggiuntive Martedì 14-17 -- Laboratorio L-12
Laboratorio LP2 Esercitazioni aggiuntive Martedì 14-17 -- Laboratorio L-12 ventre@dia.unisa.it Esercizio P14.8 Scrivete un programma Find che cerchi in tutti i file specificati sulla riga di comando una
DettagliEsempio su strutture dati dinamiche: ArrayList
Esempio su strutture dati dinamiche: ArrayList 1 ArrayList! Abbiamo detto che gli array non possono cambiare la propria dimensione: il numero di elementi contenuti viene stabilito al momento della creazione
DettagliLaboratorio di Programmazione Lezione 2. Cristian Del Fabbro
Laboratorio di Programmazione Lezione 2 Cristian Del Fabbro Prossima lezione GIOVEDÌ 29 OTTOBRE 14:00 Input da tastiera package input; import java.io.*; public class Input { public static void main(string[]
DettagliMetodi di una Collection
Java Collections Introduzione Una java collection (a volte chiamata anche container) è un oggetto che raggruppa più elementi dello stesso tipo in una singola unità. Tipicamente è utilizzata per raggruppare
DettagliProgrammazione. Cognome... Nome... Matricola... Prova scritta del 11 luglio 2014
Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 11 luglio 2014 TEMPO DISPONIBILE: 2 ore Negli esercizi
DettagliCapitolo 3. Realizzare classi
Capitolo 3 Realizzare classi Obbiettivi del capitolo Acquisire familiarità con il procedimento di realizzazione di classi Essere in grado di realizzare semplici metodi Capire a cosa servono e come si usano
DettagliIL LINGUAGGIO JAVA Input, Tipi Elementari e Istruzione Condizionale
Fondamenti di Informatica IL LINGUAGGIO JAVA Input, Tipi Elementari e Istruzione Condizionale Fondamenti di Informatica - D. Talia - UNICAL 1 Lettura di dati da input In Java la lettura di dati da input
DettagliFondamenti di Informatica. Algoritmi di Ricerca e di Ordinamento
Fondamenti di Informatica Algoritmi di Ricerca e di Ordinamento 1 Ricerca in una sequenza di elementi Data una sequenza di elementi, occorre verificare se un elemento fa parte della sequenza oppure l elemento
DettagliSTRINGHE IN JAVA In Java, le stringhe non sono pezzi di memo-ria con dentro dei caratteri, come in C: sono oggetti appartenenti alla classe
STRINGHE IN JAVA In Java, le stringhe non sono pezzi di memo-ria con dentro dei caratteri, come in C: sono oggetti appartenenti alla classe String Una stringa Java rappresenta uno specifico valore e come
DettagliProgrammazione. Cognome... Nome... Matricola... Prova scritta del 22 settembre 2014. Negli esercizi proposti si utilizzano le seguenti classi:
Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 22 settembre 2014 TEMPO DISPONIBILE: 2 ore Negli
DettagliProblemi, algoritmi e oggetti
Fondamenti di informatica Oggetti e Java Luca Cabibbo Capitolo 5 Marzo 2007 1 Fondamenti di informatica: Oggetti e Jav Contenuti... Problemi e algoritmi comprensione del problema identificazione di un
DettagliArray in Fortran 90. Ing. Luca De Santis. Anno accademico 2006/2007. DIS - Dipartimento di informatica e sistemistica
Array in Fortran 90 Ing. Luca De Santis DIS - Dipartimento di informatica e sistemistica Anno accademico 2006/2007 Fortran 90: array DIS - Dipartimento di informatica e sistemistica 1 / 25 Cosa vedremo
DettagliProgrammazione 1 A.A. 2015/2016
Cognome e Nome Matricola Programmazione 1 A.A. 2015/2016 Appello del 16 Dicembre 2015 Compito n 1 Prima parte Esercizio 1 (10 punti) Cosa stampa il seguente frammento di codice Java? int[] A = {3, 8, 91,
DettagliINFORMATICA GRAFICA - FONDAMENTI DI INFORMATICA Ing. Civile - Edile/Architettura Dott. Penzo SOLUZIONE PROVA SCRITTA DEL 16/09/2002.
INFORMATICA GRAFICA - FONDAMENTI DI INFORMATICA Ing. Civile - Edile/Architettura Dott. Penzo SOLUZIONE PROVA SCRITTA DEL 16/09/2002 Esercizio 4) import fiji.io.simplereader; class Programma{ public static
DettagliAlgoritmi di Ricerca. Esempi di programmi Java
Fondamenti di Informatica Algoritmi di Ricerca Esempi di programmi Java Fondamenti di Informatica - D. Talia - UNICAL 1 Ricerca in una sequenza di elementi Data una sequenza di elementi, occorre verificare
DettagliCapitolo 16. Programmazione generica. Cay S. Horstmann Concetti di informatica e fondamenti di Java quarta edizione
Capitolo 16 Programmazione generica Cay S. Horstmann Concetti di informatica e fondamenti di Java quarta edizione Obiettivi del capitolo Capire gli obiettivi della programmazione generica Essere in grado
DettagliEsempi di Problemi Iterativi
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica Dispensa E07 C. Limongelli Dicembre 2011 1 Contenuti q Esercizi: Palindroma Anagramma Fibonacci 2 Palindroma q Scrivere un programma che
DettagliEsercizi di Algoritmi e Strutture Dati
Esercizi di Algoritmi e Strutture Dati Moreno Marzolla marzolla@cs.unibo.it Ultimo aggiornamento: 10 novembre 2010 1 La bandiera nazionale (problema 4.7 del libro di testo). Il problema della bandiera
DettagliEsercizi classi e array
Esercizi classi e array Raffaella Brighi, a.a. 2006/07 Corso di Algoritmi e programmazione. A.A. 2006-07 CdL Operatore Informatico Giuridico. Progetto DataSet Realizzare una classe DataSet per la gestione
DettagliLaboratorio di Programmazione 1 [Java]
Laboratorio di Programmazione 1 [Java] Prova di esame - 7 Settembre 2010 Tempo massimo: 50 minuti Si implementino in Java le classi Tavolo e Ristorante. La classe Tavolo ha i seguenti attributi: numero
DettagliFondazione ITS A. Volta linguaggi Flavia Lollis 1
Si vuole simulare il funzionamento di alcune parti di un automobile della quale si conosce il tipo di carburante utilizzato, il consumo, la capacità del serbatoio e che ci permetta di simulare l inserimento
DettagliProgrammazione Orientata agli Oggetti in Linguaggio Java
Programmazione Orientata agli Oggetti in Linguaggio Java Classi e Oggetti: Metafora Parte a versione 2.2 Questo lavoro è concesso in uso secondo i termini di una licenza Creative Commons (vedi ultima pagina)
Dettagli7 - Programmazione procedurale: Dichiarazione e chiamata di metodi ausiliari
7 - Programmazione procedurale: Dichiarazione e chiamata di metodi ausiliari Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa
Dettaglisayhello public private protected return public class Greeter { public String sayhello() { String message = Hello, World! ; return message; } }
sayhello public class Greeter { public String sayhello() { String message = Hello, World! ; return message; publicprivate protected return void return; Greeter main main public class GreeterTest { public
DettagliEsempi di Problemi Iterativi
Corso di Laurea Ingegneria Civile Elementi di Informatica Esempi di Problemi Iterativi C. Limongelli Esempi di Problemi Iterativi 1 Contenuti Esercizi: Palindroma Anagramma Fibonacci Esempi di Problemi
DettagliParola chiave extends
Il Linguaggio Java Ereditarietà Ereditarietà L'ereditarietà permette di creare nuove classi sulla base di classi esistenti In particolare, permette di riusare il codice (metodi e campi); aggiungere nuovi
DettagliElementi lessicali. Lezione 4. La parole chiave. Elementi lessicali. Elementi lessicali e espressioni logiche. Linguaggi di Programmazione I
Lezione 4 Elementi lessicali e espressioni logiche Matricole 2-3 Elementi lessicali il linguaggio C ha un suo vocabolario di base i cui elementi sono detti token esistono 6 tipi di token: parole chiave
DettagliStrutture dati e loro organizzazione. Gabriella Trucco
Strutture dati e loro organizzazione Gabriella Trucco Introduzione I linguaggi di programmazione di alto livello consentono di far riferimento a posizioni nella memoria principale tramite nomi descrittivi
DettagliUn esempio di if annidati
Programmazione A.A. 2002-03 I Costrutti di base ( Lezione XIV, parte I ) Costrutto di selezione switch Prof. Giovanni Gallo Dr. Gianluca Cincotti Dipartimento di Matematica e Informatica Università di
Dettaglipublic BankAccount() { balance = 0; } public BankAccount(double initialbalance) { balance = initialbalance; }
Il Linguaggio Java Le interfacce La classe BankAccount public class BankAccount { public BankAccount() { balance = 0; public BankAccount(double initialbalance) { balance = initialbalance; public void deposit(double
DettagliEsempio: il conto bancario
Ereditarietà Prof. Francesco Scarcello D.E.I.S., Università della Calabria Corso di Informatica 2 Esempio: il conto bancario public class BankAccount { public BankAccount() { balance = 0; public BankAccount(double
DettagliDefinizione di classi
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica 1 Dispensa E05 Definizione di classi A. Miola Novembre 2006 http://www.dia.uniroma3.it/~java/fondinf1/ Definizione di classi 1 Contenuti
DettagliIl Linguaggio Java. Classe. Classi ed oggetti
Il Linguaggio Java Classi ed oggetti Classe class BankAccount { public BankAccount() { balance = 0; public void deposit(double amount) { balance += amount; public void withdraw(double amount) { balance
DettagliProgrammazione ad oggetti
DAIS Univ. Ca' Foscari Venezia Programmazione ad oggetti Samuel Rota Bulò Tipi di dato primitivo Tipo Descrizione Range bytes int interi 2147483648 2147483647 4 byte interi -128 127 1 short interi -32768
DettagliProva di Laboratorio del [ Corso A-B di Programmazione (A.A. 2004/05) Esempio: Media Modalità di consegna:
Prova di Laboratorio del 12.1.2005 [durata 90 min.] Corso A-B di Programmazione (A.A. 2004/05) 1. Leggere da tastiera un insieme di numeri interi ed inserirli in un vettore A 2. Calcolare tramite una funzione
DettagliCompito di Programmazione, 22 marzo 2007 INFORMATICI E MULTIMEDIALI
Compito di Programmazione, 22 marzo 2007 INFORMATICI E MULTIMEDIALI Esercizio 1 Si consideri la seguente classe che specifica liste di interi: public class List { private int head; private List tail; public
DettagliCompitino di Laboratorio di Informatica CdL in Matematica 13/11/2007 Teoria Compito A
Matematica 13/11/2007 Teoria Compito A Domanda 1 Descrivere, eventualmente utilizzando uno schema, gli elementi funzionali di una CPU. Domanda 2 Java è un linguaggio compilato o interpretato? Motivare
DettagliRiferimenti ad oggetti: Fondamenti di Informatica L-B Esercitazione n 4 Java: I/O, Costruttori e altro. Riferimenti ad oggetti: (Esempio)
Fondamenti di Informatica L-B Esercitazione n 4 Java: I/O, Costruttori e altro A.A. 2005/06 Tutor: Loris Cancellieri loris.cancellieri@studio.unibo.it Riferimenti ad oggetti: Cosa si può fare con i riferimenti?
DettagliLaboratorio di Matematica e Informatica 1
Laboratorio di Matematica e Informatica 1 Matteo Mondini Antonio E. Porreca matteo.mondini@gmail.com porreca@disco.unimib.it Dipartimento di Informatica, Sistemistica e Comunicazione Università degli Studi
DettagliSavingsAccount. BankAccount
BankAccount public class BankAccount { private double balance; public BankAccount(){ this(0); public BankAccount(double initialbalance) { balance = initialbalance; public void deposit(double amount) {
DettagliIl TDA Dictionary. Definizione informale. I metodi del TDA Dictionary 1. Applicazioni. I metodi del TDA Dictionary 2. I metodi del TDA Dictionary 3
Il TDA Dictionary Definizione informale Il TDA Dictionary (dizionario) modella una collezione di voci su cui è possibile effettuare delle ricerche Una voce è una coppia (chiave, elemento) Le principali
Dettagli24 - Possibili approfondimenti
24 - Possibili approfondimenti Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/ milazzo milazzo di.unipi.it
DettagliStringhe e Array. Prof. Francesco Accarino IIS Altiero Spinelli Via Leopardi 132 Sesto San Giovanni
IIS Altiero Spinelli Via Leopardi 132 Sesto San Giovanni La Classe String In Java le stringhe, a differenza della maggior parte dei linguaggi di programmazione, non sono array di caratteri (char), bensì
DettagliAlgoritmi e Strutture Dati. Tipo di dato astratto e Strutture dati elementari
Algoritmi e Strutture Dati Tipo di dato astratto e Strutture dati elementari 1 Argomenti della lezione Tipi di dato astratto Strutture dati elementari Liste o Implementazione di liste in Java Stack Code
DettagliARRAY E STRINGHE. ESERCIZIO 2 Scrivere un programma che calcola il numero di doppie e di dittonghi (2 vocali vicine) presenti in una stringa.
3 ITI - a.s. 2007-2008 Compiti di Informatica ESTATE 2008 ARRAY E STRINGHE Scrivere una funzione che carica da tastiera un array di n elementi e lo stampa invertendo il primo elemento con l'ultimo, il
DettagliL Allocazione Dinamica della Memoria
L Allocazione Dinamica della Memoria Maurizio Palesi DIIT Università di Catania Viale Andrea Doria 6, 95125 Catania mpalesi@diit.unict.it http://www.diit.unict.it/users/mpalesi Sommario Questo documento
DettagliUNIVERSITÀ DEGLI STUDI DI PAVIA FACOLTÀ DI INGEGNERIA. Matlab: esempi ed esercizi
UNIVERSITÀ DEGLI STUDI DI PAVIA FACOLTÀ DI INGEGNERIA Matlab: esempi ed esercizi Sommario e obiettivi Sommario Esempi di implementazioni Matlab di semplici algoritmi Analisi di codici Matlab Obiettivi
Dettagli22 - Strutture Dati (Java Collections Framework)
22 - Strutture Dati (Java Collections Framework) Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/
DettagliProgrammazione in Java (I modulo)
Programmazione in Java (I modulo) Lezione 4 Variabili di tipo primitivo. Dichiarazione di costanti Conversioni di tipo: operatore cast Altri operatori di assegnamento Operazioni aritmetiche e di confronto
DettagliFondamenti di Informatica I
Sapienza Università di Roma, Facoltà di Ingegneria Corso di Fondamenti di Informatica I Canale 1 (A-K) Anno Accademico 2009-2010 Corso di Laurea in Ingegneria Informatica Docente: Camil Demetrescu Esercitatore:
DettagliProgrammazione 1 A.A. 2015/2016
Cognome e Nome Matricola (se disponibile) Programmazione 1 A.A. 2015/2016 Parziale del 4 Novembre 2015 Compito n 1 Esercizio 1 (4 punti) Convertire da base 16 a base 2 il numero FA1 Convertire da base
DettagliFondamenti di Informatica 1. Prof. B.Buttarazzi A.A. 2010/2011
Fondamenti di Informatica 1 Prof. B.Buttarazzi A.A. 2010/2011 Sommario Istruzioni di controllo Iterative Condizionali Algoritmi e Diagrammi di flusso Esercizi 28/03/2011 2 Istruzioni iterative while do
Dettagli20. Appunti sulle liste (gestione in linguaggio C#) 16/04/2015 Arraylist
20. Appunti sulle liste (gestione in linguaggio C#) 16/04/2015 Arraylist Esamina il codice seguente, eseguilo passo passo (F11) e rispondi ai quesiti: using System; using System.Collections; class Program
DettagliPreparazione allo Scritto di Programmazione
Preparazione allo Scritto di Programmazione Informatica / Comunicazione Digitale A.A. 2014/2015 Matricola:...................... Cognome:...................... Nome:...................... Informatica Comunicazione
DettagliIstruzioni iterative (o cicliche)
Dipartimento di Informatica e Sistemistica Antonio Ruberti Sapienza Università di Roma Istruzioni iterative (o cicliche) Corso di Fondamenti di Informatica Laurea in Ingegneria Informatica (Canale di Ingegneria
Dettagli5 - Istruzioni condizionali
5 - Istruzioni condizionali Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/ milazzo milazzo di.unipi.it
DettagliInformatica 3 secondo recupero 13 Settembre 2002
Informatica 3 secondo recupero 13 Settembre 2002 Nome (stampatello) Cognome (stampatello) Matr Recupero: Prima prova in itinere Seconda prova in itinere spazio per il docente Punteggi recupero prima prova
DettagliIntroduzione alla Programmazione in Java attraverso un esempio commentato
Corso di Studi in Informatica Programmazione 1 corso B prof. Elio Giovannetti Introduzione alla Programmazione in Java attraverso un esempio commentato Programmazione 1 B - a.a. 2002-03 53 Modello di memoria
DettagliProgrammazione ad Oggetti
Programmazione ad Oggetti Java - IO Corso di Programmazione ad Oggetti Seconda Università di Napoli Ing. Antonio Coronato ICAR - CNR Agenda Operazioni di IO da tastiera Oggetti System per le operazioni
DettagliCOMPITO DI LABORATORIO DI PROGRAMMAZIONE 2001-2002 17 Luglio 2002. Soluzione degli Esercizi
COMPITO DI LABORATORIO DI PROGRAMMAZIONE 2001-2002 17 Luglio 2002 degli Esercizi ESERCIZIO 1. Si consideri il seguente frammento di codice in linguaggio Java: int i=0, j=0; int[][] a=b; boolean trovato=false;
DettagliProgrammazione I. 11 gennaio Considerate la seguente gerarchia di classi (rappresentata mediante un diagramma UML): +f(double x):
Programmazione I 11 gennaio 2012 Matricola:........................................................................ Cognome:........................................................................ Nome:...........................................................................
DettagliCapitolo 7 I puntatori in C
1 Capitolo 7 I puntatori in C 7.2 Dichiarazione e inizializzazione di puntatori Variabili puntatore Contengono gli indirizzi di memoria come valore Le normali variabili contengono uno specifico valore
DettagliCos è un algoritmo. Si dice algoritmo la descrizione di un metodo di soluzione di un problema che sia
Programmazione Un programma descrive al computer, in estremo dettaglio, la sequenza di passi necessari a svolgere un particolare compito L attività di progettare e realizzare un programma è detta programmazione
DettagliInput/output da file I/O ANSI e I/O UNIX FLUSSI E FILE FLUSSI FLUSSI di TESTO FLUSSI BINARI FILE
Input/output da file Il linguaggio C non contiene istruzioni di I/O, in quanto tali operazioni vengono eseguite tramite funzioni di libreria standard. Questo approccio rende estremamente flessibile e potente
DettagliI file Laboratorio di Linguaggi di Programmazione a.a. 2001/2002
I file Laboratorio di Linguaggi di Programmazione a.a. 2001/2002 dott.ssa Francesca A. Lisi lisi@di.uniba.it Sommario Generalità sui file in C I file ad accesso sequenziale I file di testo Riferimenti
DettagliFondamenti di Informatica. Dichiarazione, creazione e gestione di array in Java
Fondamenti di Informatica Dichiarazione, creazione e gestione di array in Java Array in Java - creazione La creazione fa una inizializzazione implicita: num = new int[10]; con valore 0 per int e double,
DettagliLe basi del linguaggio Java
Corso di Laurea Ingegneria Civile Fondamenti di Informatica Dispensa 10 Le basi del linguaggio Java Aprile 2010 Le basi del linguaggio Java 1 Prerequisiti Nozioni generali sulla sintassi e semantica del
DettagliUtilizza i tipi di dati comuni a tutto il framework.net Accesso nativo ai tipi.net (C# è nato con.net) Concetti fondamentali:
1 Tipi di dati 1 Tipi di dati Utilizza i tipi di dati comuni a tutto il framework.net Accesso nativo ai tipi.net (C# è nato con.net) Concetti fondamentali: Tutto è un oggetto Tutto eredita implicitamente
DettagliFondamenti di Informatica T1 Mappe
Fondamenti di Informatica T1 Mappe Tutor Melissa Licciardello melissa.licciardell2@unibo.it Melissa Licciardello Fondamenti di Informatica T1 1 / 16 Mappe Matrice N x 2 : Gli elementi della prima colonna,
DettagliInformatica 1 Tipi e dichiarazioni in C++ C++ - Tipi e dichiarazioni 1
Informatica 1 Tipi e dichiarazioni in C++ C++ - Tipi e dichiarazioni 1 Cosa è il C++ E un linguaggio di programmazione derivato dal C Può essere usato per modificare il SO Unix e i suoi derivati (Linux)
DettagliLa gestione dell input/output da tastiera La gestione dell input/output da file La gestione delle eccezioni
La gestione dell input/output da tastiera La gestione dell input/output da file La gestione delle eccezioni Autore: Prof. Agostino Sorbara ITIS "M. M. Milano" Autore: Prof. Agostino Sorbara ITIS "M. M.
DettagliAlgebra di Boole: Concetti di base. Fondamenti di Informatica - D. Talia - UNICAL 1. Fondamenti di Informatica
Fondamenti di Informatica Algebra di Boole: Concetti di base Fondamenti di Informatica - D. Talia - UNICAL 1 Algebra di Boole E un algebra basata su tre operazioni logiche OR AND NOT Ed operandi che possono
DettagliPROGRAMMAZIONE: Le strutture di controllo
PROGRAMMAZIONE: Le strutture di controllo Prof. Enrico Terrone A. S: 2008/09 Le tre modalità La modalità basilare di esecuzione di un programma è la sequenza: le istruzioni vengono eseguite una dopo l
DettagliProgrammazione generica
16 Programmazione generica Obiettivi del capitolo Capire gli obiettivi della programmazione generica Essere in grado di realizzare classi e metodi generici Comprendere il meccanismo di esecuzione di metodi
DettagliOO puro. Primi concetti di Java. Tipi primitivi. Ogni cosa è un oggetto. Java è object-oriented puro Non come il C+ + (OO ibrido) Lorenzo Bettini
Primi concetti di Java Lorenzo Bettini OO puro Java è object-oriented puro Non come il C+ + (OO ibrido) Per compatibilità col C Ogni cosa è un oggetto Gli oggetti si manipolano tramite riferimenti String
DettagliStrutture di controllo iterative
Capitolo 4 Strutture di controllo iterative ANDREA GINI Le strutture di controllo iterative permettono di impostare la ripetizione di un insieme di istruzioni per un determinato numero di volte. In Java
DettagliProgrammazione Orientata agli Oggetti. Emilio Di Giacomo e Walter Didimo
Programmazione Orientata agli Oggetti Emilio Di Giacomo e Walter Didimo Una metafora dal mondo reale la fabbrica di giocattoli progettisti Un semplice giocattolo Impara i suoni Dall idea al progetto Toy
DettagliProgetto Automi e Linguaggi Parser svliluppato con JLex e cup
Progetto Automi e Linguaggi Parser svliluppato con JLex e cup Sviluppato da Santoro Carlo Maurizio Matricola:0108/528 Sviluppo terminato il: 18/06/06 TRACCIA DEL PROGETTO Si costruisca, utilizzando la
DettagliFondamenti di Programmazione. Strutture di controllo
Fondamenti di Programmazione Strutture di controllo 1! Controllo del flusso! n Flusso di esecuzione: ordine in cui le istruzioni di un programma sono eseguite! n Salvo contrordini, è in sequenza! n Due
DettagliArgomenti Avanzati.! I puntatori! Stack! Visibilità delle Variabili
Linguaggio C Argomenti Avanzati! I puntatori! Stack! Visibilità delle Variabili 2 ! Il C consente di associare ai tipi di dati nomi definiti dal programmatore, mediante la parola chiave typedef! Dal punto
DettagliADT: Abstract Data Type. Quasi ADT. ADT per collezioni di dati (code generalizzate) 04 I tipi di dati astratti (I parte)
ADT: Abstract Data Type I tipi di dati astratti (I parte) Gianpiero Cabodi e Paolo Camurati Dip. Automatica e Informatica Politecnico di Torino Scopo Livello di astrazione sui dati tale da mascherare completamente
DettagliCostrutti condizionali e iterativi
Costrutti condizionali e iterativi Introduction to Fortran 90 Paolo Ramieri, CINECA Aprile 2014 Strutture di controllo Le strutture di controllo permettono di alterare la sequenza di esecuzione delle istruzioni
Dettagli// inizializzazione della biblioteca con utenti, libri e prestiti // non richiesta Biblioteca.inizializza();
// Fondamenti di Informatica/Informatica Grafica // Soluzione del compito del 21/03/2003 // per semplicità si è deciso di riportare in un unico file il testo // delle soluzioni degli esercizi 1, 2 e 3.
DettagliC. Horstmann Fondamenti di programmazione e Java 2 3^ edizione Apogeo
File e Flussi C. Horstmann Fondamenti di programmazione e Java 2 3^ edizione Apogeo trad. Nicola Fanizzi corso di Programmazione, CdS: Informatica TPS Dip. di Informatica, Università degli studi di Bari
DettagliFile, flussi e pacchetto java.io
File, flussi e pacchetto java.io Formato binario e formato di testo I dati sono memorizzati nei files in due formati: testo (successione di caratteri) binario (successione di bytes) Ad es. numero 12345
DettagliGestione di files Motivazioni
Gestione di files Motivazioni Un programma in esecuzione legge (sequenzialmente) una sequenza di caratteri prodotti "al volo" dall'utente (tramite tastiera) il programma in esecuzione scrive (sequenzialmente)
DettagliEsercizi della lezione 5 di Java
Esercizi della lezione 5 di Java Esercizio 5 Create il tipo di dato Counter dell Esercizio 1 come sottoclasse del tipo di dato SimpleCounter. Esercizio 1 Create un tipo di dato Counter che abbia: un valore
DettagliCorso di Laurea Ingegneria Civile Fondamenti di Informatica. Esercizi sui metodi. Carla Limongelli. Maggio Esercizi 1
Corso di Laurea Ingegneria Civile Fondamenti di Informatica Esercizi sui metodi Carla Limongelli Maggio 2010 Esercizi 1 Passaggio di parametri di tipo primitivo Indicare che cosa viene visualizzato sullo
DettagliCapitolo 4. Tipi di dati fondamentali. Cay S. Horstmann Concetti di informatica e fondamenti di Java quarta edizione
Capitolo 4 Tipi di dati fondamentali Cay S. Horstmann Concetti di informatica e fondamenti di Java quarta edizione Obiettivi del capitolo Apprendere l utilizzo di numeri interi e di numeri in virgola mobile
DettagliIstruzioni di ripetizione in Java 1
in Java Corso di laurea in Informatica Le istruzioni di ripetizione consentono di eseguire molte volte la stessa Si chiamano anche cicli Come le istruzioni condizionali, i cicli sono controllati da espressioni
Dettagli3. La sintassi di Java
pag.9 3. La sintassi di Java 3.1 I tipi di dati statici In Java, come in Pascal, esistono tipi di dati statici predefiniti e sono i seguenti: byte 8 bit da -128 a 127 short 16 bit coincide con l integer
DettagliClassi ed Oggetti in JAVA
Classi ed Oggetti in JAVA Dott. Ing. Leonardo Rigutini Dipartimento Ingegneria dell Informazione Università di Siena Via Roma 56 53100 SIENA Uff. 0577233606 rigutini@dii.unisi.it www.dii.unisi.it/~rigutini/
DettagliCorso di Laurea in Ingegneria Gestionale Esame di Informatica - a.a luglio 2013
Cognome Nome Matricola Postazione PC Corso di Laurea in Ingegneria Gestionale Esame di Informatica - a.a. 2012-13 04 luglio 2013 Testo Il database di una banca è costituito da due vettori paralleli. Il
Dettagli