Istruzioni di ripetizione in Java

Slides:



Advertisements
Presentazioni simili
Programma: main() { istruzioni } ; assegnazione condizione ciclo istruzione: ;
Advertisements

Iterazione while – do while - for.
Iterazione A. Ferrari.
PROGRAMMARE IN PASCAL (le basi)
3TC – 5/11/2010 Cicli while e do.. While Contatori e Totalizzatori.
Sviluppo di programmi strutturati
PHP.
© 2007 SEI-Società Editrice Internazionale, Apogeo Unità F3 Iterazione.
Universita di Camerino
Istruzioni condizionali e blocco
MATLAB.
Algoritmi e Programmazione
INFORMATICA Strutture iterative
Introduzione agli algoritmi. Definizione Sistema di regole e procedure di calcolo ben definite che portano alla soluzione di un problema con un numero.
1 Università della Tuscia - Facoltà di Scienze Politiche.Informatica 2 - a.a Prof. Francesco Donini Istruzioni iterative For, while.
Iterazione enumerativa (for)
Tipi di dato e controllo del flusso Dott. Ing. Leonardo Rigutini Dipartimento Ingegneria dellInformazione Università di Siena Via Roma 56 – – SIENA.
Informatica Problema Algoritmo Programma
Prof.ssa Chiara Petrioli -- Fondamenti di programmazione 1, a.a. 2009/2010 Corso di Fondamenti di programmazione a.a.2009/2010 Prof.ssa Chiara Petrioli.
Prof.ssa Chiara Petrioli -- corso di programmazione 1, a.a. 2006/2007 Corso di Programmazione 1 a.a.2006/2007 Prof.ssa Chiara Petrioli Corso di Laurea.
Informatica 2. Concetti fondamentali di programmazione Programmare vuol dire scrivere un algoritmo in un linguaggio che faccia funzionare un calcolatore.
1 Corso di Informatica (Programmazione) Lezione 11 (19 novembre 2008) Programmazione in Java: controllo del flusso (iterazione)
1 Corso di Informatica (Programmazione) Lezione 10 (12 novembre 2008) Programmazione in Java: espressioni booleane e controllo del flusso (selezione)
Corso di Laurea in Biotecnologie Informatica (Programmazione)
MATLAB. …oggi… Programmare in Matlab Programmare in Matlab Funzioni Funzioni Cicli Cicli Operatori relazionali Operatori relazionali Esercizi vari Esercizi.
Programmazione Un programma descrive al computer, in estremo dettaglio, la sequenza di passi necessari a svolgere un particolare compito L’attività di.
Introduzione alla programmazione lll
ITERAZIONE e RICORSIONE (eseguire uno stesso calcolo ripetutamente) ITERAZIONE: ripetere piu volte una sequenza di operazioni istruzioni: for, while, do.
Lezione 4: Costrutti Condizionali Prof. Raffaele Montella.
Fondamenti di Informatica I a.a Il linguaggio C Il controllo di flusso La selezione condizionale Listruzione switch I cicli Le istruzioni break,
ITERAZIONE e RICORSIONE (eseguire uno stesso calcolo ripetutamente)
Programmazione Corso di laurea in Informatica
Istruzioni di selezione in Java Programmazione Corso di laurea in Informatica.
Approfondimento delle classi
Selezione (=scelta) con “if-else”
Istruzioni Iterative Nicola Fanizzi
Iterazioni (for, do, while). Lab.Calc. AA2005/062 Iterazioni 3 istruzioni che consentono di eseguire un loop (ciclo): 1. while 2. do...while 3. for con.
Strutture di controllo nel C
Java base II: Strutture di Controllo
CODIFICA Da flow-chart a C++.
Cicli in Fortran I cicli consentono di eseguire una sequenza di istruzioni più di una volta due tipi: Cicli iterativi Cicli while.
Programmazione di Calcolatori
ISTITUTO STATALE DI ISTRUZIONE SUPERIORE F. ENRIQUES CORSO JAVA – PROVA INTERMEDIA DEL 12 MARZO 2007 NOME: COGNOME: ________________________________________________________________________________.
Parte 4 Elementi di Informatica di base
Lezione 7 Strutture di controllo Il ciclo while
Laboratorio di Informatica1 Parte 4 Laboratorio di Informatica Dott.ssa Elisa Tiezzi Dott.ssa Elisa Mori.
BIOINFO3 - Lezione 221 Listruzione IF-ELSE prevede un secondo blocco di istruzioni da eseguire in alternativa al primo nel caso la condizione sia falsa.
Capitolo 4 (Deitel) Le strutture di controllo in C
ISTITUTO STATALE DI ISTRUZIONE SUPERIORE F. ENRIQUES CORSO JAVA – PROVA INTERMEDIA DEL 12 MARZO 2007 NOME: COGNOME: ________________________________________________________________________________.
Programmazione Strutturata
Anno accademico Le istruzioni di controllo in C.
L’iterazione while La sintassi è la seguente: while (condizione) {
Ripetizione La vera potenza dei programmi per computer risiede nella capacità di ripetere lo stesso calcolo o sequenza di istruzioni più volte, ogni volta.
TURBOPASCAL L’iterazione - prof. V. Riboldi -.
Corso JAVA Lezione n° 03 Istituto Statale di Istruzione Superiore “F. Enriques”
Introduzione a Javascript
R 255 G 211 B 8 R 255 G 175 B 0 R 127 G 16 B 162 R 163 G 166 B 173 R 104 G 113 B 122 R 234 G 234 B 234 R 175 G 0 B 51 R 0 G 0 B 0 R 255 G 255 B 255 Supporting.
1 Università della Tuscia - Facoltà di Scienze Politiche.Informatica 2 - a.a Prof. Francesco Donini Istruzioni iterative For, while.
Capitolo 6 Iterazione Lucidi relativi al volume: Java – Guida alla programmazione James Cohoon, Jack Davidson Copyright © The McGraw-Hill Companies.
Tecnologie Informatiche ed Elettroniche per le Produzioni Animali
1 Fabio Scotti – Università degli Studi di Milano Fabio Scotti ( ) Laboratorio di programmazione per la sicurezza Valentina Ciriani ( )
13 ottobre Decisioni F. Bombi 13 ottobre 2002.
Linguaggio C: Le basi Stefano Cagnoni e Monica Mordonini
Linguaggio C: Le basi Stefano Cagnoni e Monica Mordonini
Informatica 4 La ricorsione. Definizione di ricorsione Ricorsione è la proprietà di quei programmi che, all’interno delle istruzioni che li compongono,
Eprogram informatica V anno. Introduzione a PHP Introduzione La diffusione di PHP ha avuto un notevole incremento dalla fine degli anni Novanta a oggi,
Strutture di controllo
Università di Torino – Facoltà di Scienze MFN Corso di Studi in Informatica Programmazione I - corso B a.a prof. Viviana Bono Blocco 6 – Invariante.
Cicli e Array. 2 Costrutto while while(espressione) { … } Il codice dentro le parentesi graffe viene eseguito finché la condizione è vera Potrebbe non.
Basi di Java Strutture base di Java. Basi di java ▪Variabili ▪Operatori ▪Condizioni e Cicli ▪Array.
Transcript della presentazione:

Istruzioni di ripetizione in Java Programmazione Corso di laurea in Informatica

Istruzioni di ripetizione Le istruzioni di ripetizione consentono di eseguire molte volte la stessa istruzione Si chiamano anche cicli Come le istruzioni condizionali, i cicli sono controllati da espressioni booleane in Java: il ciclo while, il ciclo do, e il ciclo for I diversi tipi sono approriati in situazioni diverse AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione while Sintassi dell’istruzione while: while ( condizione ) è parola riservata Se condizione è vera, viene eseguita istruzione Quindi si valuta ancora condizione istruzione viene eseguita ripetutamente fino a che la condizione non diventa falsa AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Semantica del ciclo while condizione falso vero istruzione AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione while Se la condizione di un ciclo while è inizialmente falsa, il ciclo non viene mai eseguito Quindi un ciclo while può essere eseguito 0 o più volte Counter.java Average.java e Average2.java per ovviare al possibile problema dell’overflow WinPercentage.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Cicli infiniti Il corpo di un ciclo deve alla fine rendere falsa la condizione perchè il ciclo si fermi Altrimenti è un ciclo infinito, che viene eseguito finché l’utente non interrompe il programma Forever.java Un errore logico non infrequente Assicuratevi che i vostri cicli abbiano sempre termine AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione for La sintassi dell’istruzione for L’istruzione viene eseguita fino a che condizione diventa falsa Parola riservata Espressione di inizializzazione è eseguita una volta prima di entrare nel ciclo for ( inizializzazione; condizione; aggiornamento ) istruzione; Espressione di incremento viene eseguita alla fine di ciascuna iterazione AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione for Un ciclo for è equivalente al ciclo while: inizializzazione; while ( condizione ) { istruzione; incremento; } AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Semantica del ciclo for inizializzazione condizione falsa istruzione vera incremento AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Variabili definite nel for La variabile che controlla il ciclo for può essere definita all’interno del ciclo e sarà visibile solo nel ciclo La sua durata di vita è legata a quella del ciclo A ciclo finito la variabile non esiste più for (int i = 1; i<=n; i++) … AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione for La condizione di un ciclo for viene valutata prima di eseguire il ciclo, come nel ciclo while Di conseguenza, il corpo del ciclo for può essere eseguito 0 o più volte Questo ciclo è indicato per eseguire istruzioni un numero di volte specifico che può essere determinato a priori Counter3.java Multiples.java Palindrome.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Cicli innestati Anche i cicli possono essere innestati Il corpo del ciclo contiene un altro ciclo Come le istruzioni if-else Ogni nuovo ingresso nel ciclo esterno causa un’intera esecuzione del ciclo interno PalindromeTester.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione do La sintassi dell’istruzione do: do { istruzione; } while ( condizione ) Le parole riservate do while L’istruzione viene inizialmente eseguita una volta, poi la condizione è valutata nuovamente e ripetutamente eseguita fino a che la condizione non diventa falsa AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Semantica del ciclo do istruzione vera condizione falsa AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Istruzione do Il ciclo do è simile al ciclo while, tranne che la condizione è valutata dopo che il corpo del ciclo viene eseguito Il corpo del ciclo viene sempre eseguito almeno 1 volta Counter2.java ReverseNumber.java TestPrimo.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Confronto tra i cicli while e do ciclo while ciclo do istruzione condizione vera falsa condizione vera falsa istruzione AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Esempi di ciclo Azzerare la somma Eseguire Finchè ci sono frazioni Acquisire una frazione Aggiornare la somma Finchè ci sono frazioni Scrivere la somma ottenuta nel ciclo SommaFrazioni.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Ancora istruzione for Ogni espressione nella dichiarazione di un ciclo for è opzionale manca l’espressione di inizializzazione: nessuna inizializzazione viene effettuata manca l’espressione della condizione: si considera che sia sempre vera, e si realizza un ciclo infinito manca l’espressione di aggiornamento: non si esegue nessun aggiornamento Ma il carattere ; è sempre necessario anche quando manca l’espressione corrispondente AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Dichiarazioni multiple Si possono definire all’interno del for più variabili for (int i=0, j=5; i<=10; i++, j--) … Per la leggibilità del codice rimane meglio int j = 5; for (int i=0; i<=10; i++) { … j--; } AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

L’istruzione vuota Nei cicli for si possono avere situazioni tipo: for (anno=1; (saldo=saldo+saldo*interesse/100) < obiettivo; anno++) ; Alla fine del ciclo l’unica cosa importante sarà il valore della variabile anno Ricordarsi però il ;, altrimenti l’struzione successiva diventa il corpo del ciclo AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Cicli innestati String s = “”; for (int i = 1; i <= MAX; i++) { for (int j = 1; j <= i; j++) s = s + ‘*’; s = s + ‘\n’; } Il ciclo interno dipende dalla varabile che controlla il ciclo esterno. CicloInnestato.java Stars.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Contare le iterazioni I limiti del ciclo sono asimmetrici for (int i=0; i<10; i++) la variabile di controllo i varia 0  i < 10 I limiti sono simmetrici for (int i=0; i<=10; i++) la variabile di controllo i varia 0  i  10 Per cicli asimmetrici è più facile il conteggio dell’iterazioni Quanti n umeri ci sono tra 0 e 10 estremi inclusi? Questo errore dovuto a +1 è frequente AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Elaborazione di dati in input Spesso capita di dover elaborare una serie di numeri che vengono letti da input boolean fatto = false; while (!fatto) { String riga = leggi la riga; if (i dati sono terminati) fatto = true; else elabora i dati } AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Elaborazione di dati in input La verifica della fine dei dati avviene all’interno del ciclo Prima occore cercare di leggere qualcosa Comincia a fare il lavoro, verifica che tutto sia a posto, procedi nel lavoro Ecco perché serve anche una variabile booleana Es: DataSet.java e TestInput.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Leggere i dati di input La classe JOptionPane offre un metodo di classe showInputDialog che mostra una finestra di dialogo per ricevere dati di tipo diverso La finestra restituisce i dati sottoforma di stringa Se si devono leggere numeri le stringhe vanno trattate con i metodi di classe Integer.parseInt(String) e Double.parseDouble(String) Il programma va terminato con l’istruzione System.exit(0) exit termina l’esecuzione e il parametro 0 indica che termina in modo corretto AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Migliorare la leggibilità del ciclo Assegnamento con effetto collaterale while ( (riga = JOptionPane.showInputDialog(“input…”)) != null) { elabora il dato } In generale gli effetti collaterali sono da evitare, ma in questo caso fa risparmiare l’uso della variabile boolean per controllare il ciclo while AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Enunciato break e continue L’istruzione break serve per interrompere un ciclo Nell’istruzione switch interrompe l’esecuzione limitandola all’istruzioni del blocco corrispondente all’etichetta che eguaglia l’espressione che controlla il ciclo L’istruzione continue interrompe il passo corrente del ciclo e lo riprende con il passo successivo AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Esempi for (int i = 0; i < 100; i++) { if (i == 15) break; if (i % 5 != 0) continue; System.out.println (i); } int i = 0; while (true) { i++; int j = i * 4; if (j == 40) break; if (i % 10 == 0) continue; BreakContinue.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Migliorare la leggibilità del ciclo Uso dell’istruzione break while (true) { String riga = JOptionPane.showInputDialog(“input…”) if (riga == null) break; { elabora il dato } AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Esempi Palindrome: for (int i = 0; i < f; i++, f--) if (s.charAt(i) != s.charAt(f)){ palindrome = false; break;} Interrompe il ciclo quando incontra 2 car  Occorre comunque fare un test successivo (palindrome) per sapere come si è usciti dal ciclo AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Esempi Sommari numeri pari da input, 0 per terminare: do { x = Keyboard.readInt(); if (x == 0) break; if (x % 2 != 0) continue; somma += x; } while (true) Con break si termina il ciclo Con continue si termina il passo corrente AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Cercare in una stringa di caratteri Spesso si devono esaminare i singoli caratteri di una stringa Uso dei metodi charAt() e length() for (int i=0; i<s.length(); i++) { char car = s.charAt(i); elabora car } Es: ContaVocali.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Cercare in una riga di input L’input spesso viene letto in un’unica riga che può contenere diversi dati di input e che quindi va decomposta la riga: 1.5 100 4.23 4 potrebbe dare errore, anche se l’intenzione è chiara Va usata la classe StringTokenizer del pacchetto java.util AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

La classe StringTokenizer La classe StringTokenizer è definita nel pacchetto java.util Un oggetto StringTokenizer separa una stringa di caratteri in sottostringhe più piccole (tokens) Il costruttore StringTokenizer riceve come parametro la stringa originale da separare Per default, il tokenizer separa la stringa di input agli spazi bianchi Ogni invocazione del metodo nextToken riporta il prossimo token nella stringa di input AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Uso della classe StringTokenizer Costruire un oggetto della classe StringTokenizer tokenizer = new StringTokenizer(input); Invocare il metodo nextToken per ottenere un elemento alla volta tokenizer.nextToken(); Attenzione: se non ci sono più elementi nell’input si ha errore while (tokenizer.hasMoreToken()) { fai cose e vedi gente } AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

I separatori di token Di default il separatore di elementi per la classe StringTokenizer è lo spazio È possibile cambiare il separatore Con virgole o punti Va specificato nel costruttore new StringTokenizer(input, “,”); In questo caso gli spazi vengono presi come parte integrante del token AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione

Esempi TestInput_2.java e DataSet.java PigLatin.java e PigLatinTranslator.java ExamGrades.java AA2003/04 © M.A. Alberti Programmazione Istruzioni di ripetizione