Algoritmi, dati e programmi

Dimensione: px
Iniziare la visualizzazioe della pagina:

Download "Algoritmi, dati e programmi"

Transcript

1 Algoritmi, dati e programmi 1 Scopo della lezione Introduzione ai concetti di: problema dato algoritmo linguaggio di programmazione programma diagramma di flusso 2 1

2 Informatica informatica informazione mezzi fisici mezzi procedure rappresentazione dell informazione calcolatori programmi 3 Elaborazione di informazione Ogni problema di elaborazione di informazione è caratterizzato da un insieme di dati di partenza un risultato cercato Ogni sua soluzione è una procedura che genera un risultato sulla base dei dati indicati 4 2

3 Elaborazione dell informazione Es. Problema di elaborazione dell informazione: Quanto fa 21+32? Dati di partenza: {21,32} Risultato cercato: {53} Soluzione: procedura per l addizione (addizione delle unità con riporto + addizione delle decine con riporto,...) = Elaborazione di informazione Distinguiamo tra: conoscenza di come si risolve un problema analisi del problema identificazione di una soluzione descrizione della soluzione effettiva capacità di risolvere un problema interpretazione della soluzione attuazione della soluzione 6 3

4 Elaborazione di informazione Es. Problema di elaborazione dell informazione: Quanto fa 21+32? Conoscenza di come si risolve il problema: Analisi è un problema di somma tra due numeri interi; Identificazione di una soluzione esiste una procedura per la somma tra due numeri interi; Descrizione della soluzione i due numeri interi vanno incolonnati, si sommano le unità, il riporto viene sommato alla somma delle decine, il riporto viene sommato alla somma delle centinaia,... Effettiva capacità di risolvere il problema: Interpretazione della soluzione un utente italiano legge la descrizione del problema e comprende le operazioni da eseguire; Attuazione della soluzione = Elaborazione di informazione La conoscenza di come si risolve un problema è ciò che ci permette di sviluppare un programma. Il programma sarà poi interpretato ed eseguito da un esecutore (es.: essere umano, calcolatore,...) Sono competenze distinte. 8 4

5 Elaborazione di informazione Conoscenza di come si risolve un problema Scoperta / invenzione di un algoritmo per la risoluzione di un problema Richiede uno sforzo creativo. Risoluzione del problema Intepretazione di un linguaggio ed esecuzione di una serie di operazioni Operazioni meccaniche. 9 Elaborazione di informazione Analisi del problema Individuazione dell algoritmo Scrittura del programma Ambito scientifico del problema Programmazione Dati Intepretazione del programma Esecuzione del programma Calcolatore Risultato 10 5

6 Elaborazione di informazione Per la descrizione della soluzione si utilizza: linguaggio naturale italiano, inglese, sono linguaggi ambigui Es. in una ricetta, Aggiungere un pizzico di sale Quanto è un pizzico di sale? linguaggio formale formalismo matematico pseudo-codice diagramma di flusso (flow-chart) linguaggio di programmazione codice macchina sono linguaggi non ambigui 11 Elaborazione di informazione La descrizione della soluzione può essere fatta a diversi livelli di dettaglio: Esempio: cucinare le lasagne al forno preparare il ragù Alto livello preparare la besciamella setacciare 50g di farina e stemperarla con 10cc di latte aggiungere 30cc di latte e 50g di burro a pezzetti. bollire le lasagne mettere a strati nella teglia e cuocere in forno Basso livello 12 6

7 Elaborazione di informazione Analisi del problema Individuazione dell algoritmo Scrittura del programma Ambito scientifico del problema Programmazione Dati Intepretazione del programma Esecuzione del programma Calcolatore Risultato 13 Algoritmo algoritmo [al-go-rìt-mo] s.m. Dal Dal nome del matematico ar. Al-Khuwa rizmi (sec. IX): 1 (mat.) procedimento sistematico di calcolo: algoritmo algebrico, euclideo 2 nel Medioevo, il calcolo basato sull'uso delle cifre arabiche 3 in logica matematica, procedimento meccanico che permette la risoluzione di problemi mediante un numero finito di passi (inform.) serie di operazioni logiche e algebriche, espresse in linguaggio comprensibile all'elaboratore, la cui sequenza costituisce un programma. Fonte: Dizionario Garzanti on-line ( 14 7

8 Algoritmo La descrizione rigorosa di un metodo che consente di ottenere un risultato attraverso passi elementari si chiama algoritmo. Definizione di algoritmo: un insieme ordinato di passi eseguibili e non ambigui che determinano un procedimento atto a risolvere un problema o una classe di problemi utilizzando dati iniziali e ottenendo dei risultati in un tempo finito. 15 Algoritmo Esempi: gli algoritmi per eseguire le 4 operazioni che ci sono stati insegnati alle elementari in un linguaggio adatto ai bambini la ricetta per fare le lasagne linguaggio dei libri di cucina livello di dettaglio diverso a seconda delle competenze dell esecutore ( linguaggi a basso / alto livello). Att.ne! L algoritmo è indipendente dal linguaggio nel quale viene espresso! 16 8

9 Esempi di algoritmi Algoritmo per accedere a un PC del laboratorio Accendere lo schermo se è spento Scrivere il proprio <username> nella riga in cui compare la scritta login: Scrivere la propria <password> nella riga in cui compare la scritta password Se il sistema risponde con la frase: «utente non abilitato», chiamare il tutor 17 Esempi di algoritmi (2)

10 Esempi di algoritmi (3) 19 Linguaggio e algoritmo Att.ne! Il linguaggio con cui è espresso l algoritmo non fa parte dell algoritmo! Es. l algoritmo per effettuare la somma tra due numeri è lo stesso sia in inglese che in italiano Ciò che cambia è la rappresentazione dell algoritmo, non l algoritmo! 20 10

11 Elaborazione di informazione Analisi del problema Individuazione dell algoritmo Scrittura del programma Ambito scientifico del problema Programmazione Dati Intepretazione del programma Esecuzione del programma Calcolatore Risultato 21 Linguaggio Un linguaggio è costituito da: un vocabolario; una sintassi, cioè un insieme di regole che specificano come comporre i vocaboli per ottenere costrutti ben formati (sintatticamente corretti); una semantica, che associa un significato ad ogni costrutto linguistico sintatticamente corretto

12 Sintassi e semantica Sintassi Semantica Esempi Girare la carta Un lato grigio Distinguere tra i due lati Piegare a monte rappresenta Piegare a valle Ripiegare Piegare internamente rappresenta produce produce 23 Elaborazione di informazione Analisi del problema Individuazione dell algoritmo Scrittura del programma Ambito scientifico del problema Programmazione Dati Intepretazione del programma Esecuzione del programma Calcolatore Risultato 24 12

13 Esecutore di algoritmi Un esecutore è un soggetto in grado di attuare le azioni specificate in un algoritmo Nei casi esemplificati, noi 25 Esecutore di algoritmi Un esecutore è quindi caratterizzato da: il linguaggio che è in grado di interpretare l insieme di azioni che è in grado di compiere l insieme delle regole che ad ogni costrutto linguistico sintatticamente corretto associano le relative azioni da compiere

14 Esecutore di algoritmi A seconda dell insieme delle azioni, differenti esecutori possono usare algoritmi diversi per risolvere uno stesso problema Nel caso della divisione, un computer NON userebbe l algoritmo proposto nell esempio! Es. algoritmo per spostarsi avanti di un metro: muovi le gambe per un esecutore umano; muovi le ruote per un robot. CPU diverse possono utilizzare operazioni elementari diverse per eseguire semplici istruzioni! (es. utilizzano algoritmi diversi per la somma) 27 Elaborazione di informazione Analisi del problema Individuazione dell algoritmo Scrittura del programma Ambito scientifico del problema Programmazione Dati Intepretazione del programma Esecuzione del programma Calcolatore Risultato 28 14

15 Programmi I programmi sono sequenze finite di istruzioni, ognuna scritta in un fissato linguaggio (di programmazione) I programmi eseguibili da un computer devono essere scritti usando un linguaggio che il computer è in grado di comprendere. 29 Programmi e algoritmi Un algoritmo può essere quindi specificato sottoforma di programma eseguibile da un calcolatore. Att.ne! Programma e algoritmo sono concetti diversi! Algoritmo = concetto astratto; Programma = sequenza finita di istruzioni in un determinato linguaggio Può essere la rappresentazione di un algoritmo Ma la sequenza di operazioni può anche non terminare in un tempo finito! 30 15

16 Linguaggi di programmazione Un linguaggio di programmazione è costituito da: un vocabolario un insieme di regole sintattiche che specificano come comporre istruzioni ben formate una semantica che associa un significato alle istruzioni ben formate, cioè l azione denotata da ciascuna istruzione. 31 Linguaggi di programmazione Rispetto ad una qualsiasi lingua parlata da esseri umani, un linguaggio di programmazione è molto più semplice, perché la sua sintassi è molto semplice. La teoria dei linguaggi formali fornisce una classificazione dei linguaggi in base alla loro semplicità

17 Linguaggi di basso livello Linguaggi di programmazione le cui istruzioni corrispondono ad azioni molto elementari. Richiedono uno sforzo di codifica maggiore da parte di un programmatore. 33 Linguaggi di alto livello Linguaggi di programmazione alle cui istruzioni corrisponde un insieme di azioni più articolato. Richiedono uno sforzo di codifica inferiore da parte di un programmatore

18 Esempio Il linguaggio L1 mette a disposizione i comandi: Aggiungi_una_unità al dato A Leggi dato A Leggi dato B Esegui per <numero di volte> 35 Esempio Il linguaggio L2 mette a disposizione i comandi: Leggi dato A Leggi dato B Somma <addendo1, addendo2> 36 18

19 Esempio (2) Vogliamo scrivere un programma per sommare due numeri A e B: In L1 In L2 Leggi dato A Leggi dato A Leggi dato B Leggi dato B Esegui per B volte: Aggiungi _una_unità al Somma (A, B) dato A 37 Esempio (3) L2 è un linguaggio di livello più alto rispetto a L1, perché offre al programmatore la possibilità di usare istruzioni che sono meno vicine al modo in cui lavora il processore e più vicine al modo in cui lavoriamo noi

20 Esempio (4) Basso livello preleva dalla memoria il contenuto della cella A e mettilo nel registro AA della CPU ; preleva dalla memoria il contenuto della cella B e mettilo nel registro BB della CPU ; Somma i registri AA e BB e metti il risultato nel registro CC della CPU ; Copia in memoria il registro CC della CPU, in posizione C. C = A + B. Alto livello 39 Linguaggio macchina Il processore è in grado di riconoscere (e quindi di eseguire) solo programmi scritti in un proprio linguaggio di basso livello (linguaggio macchina). Ogni modello di processore (es: Intel, Pentium, Motorola, PowerPC) ha un proprio linguaggio macchina diverso da quello degli altri processori

21 Linugaggio macchina diversi processori Un processore di tipo A ha N registri; Un processore di tipo B ha M>N registri; Per il processore A, ogni istruzione che utilizza i registri da N+1 a M non ha senso! Anche la sintassi o l insieme di istruzioni del linguaggio possono essere diverse. 41 Linugaggio macchina diversi processori Un processore di tipo A implementa direttamente la funzione prodotto ; Un processore di tipo B implementa l operazione somma ma non l operazione prodotto ; Per il processore B, non è disponibile l operazione prodotto nel linguaggio a basso livello! L insieme di istruzioni del linguaggio macchina sono diverse per A e B. Il processore B potrà essere utilizzato per fare dei prodotti utilizzando un ciclo e l operazione somma

22 Linguaggi di alto livello Un programma scritto in un linguaggio diverso dal linguaggio macchina deve essere quindi tradotto nel linguaggio che il processore sa riconoscere I soggetti preposti a questa traduzione sono a loro volta dei programmi (interpreti e compilatori) Compilatore traduce un programma per intero, poi il programma può essere eseguito (es. programmazione in C, compilatore Microsoft); Inerprete traduce ed esegue un istruzione immediatamente (es. Matlab). 43 Interpreti e compilatori Programma (istruzione) in linguaggio macchina Intel Processore Intel Programma (istruzione) in linguaggio ad alto livello Interprete o compilatore Programma (istruzione) in linguaggio macchina Athlon Processore Athlon Programma (istruzione) in linguaggio macchina Motorola Processore Motorola 44 22

23 Un confronto Linguaggio macchina Linguaggi di alto livello Velocità Portabilità Complessità 45 Una nota sulla velocità Molti linguaggi di alto livello vengono tradotti in linguaggio macchina da un apposito traduttore (detto compilatore), ottenendo in questo modo delle ottime prestazioni anche in termini di velocità Esempi: C, PASCAL JAVA si trova a metà strada 46 23

24 Elaborazione di informazione Analisi del problema Individuazione dell algoritmo Scrittura del programma Ambito scientifico del problema Programmazione Dati Intepretazione del programma Esecuzione del programma Calcolatore Risultato 47 Dal problema al programma Per costruire un programma conviene procedere con metodo, passando da un analisi del problema da risolvere all algoritmo di soluzione rappresentato in un linguaggio adatto all uomo ma non troppo lontano dai linguaggi di programmazione e infine al programma scritto nel linguaggio di programmazione prescelto 48 24

25 Dal problema al programma Riassumendo, il processo di sviluppo di un programma prevede le seguenti fasi: analisi del problema e specificazione dei dati in ingresso e in uscita; identificazione e formalizzazione di una soluzione, definizione dell algoritmo risolutivo; programmazione in un linguaggio di programmazione ad alto livello ; traduzione in linguaggio macchina; verifica (testing). 49 Dal problema al programma Approccio top-down alla progettazione: si parte da una descrizione ad alto livello della soluzione, in cui si individuano sotto-problemi si definiscono le soluzioni dei sotto-problemi in termini di operazioni più elementari e così via, fino ad esprimere tutto in termini di problemi elementari. [Programmazione bottom-up meno intuitiva si parte dalla risoluzione dei singoli sottoproblemi, si assemblano poi le soluzioni dei sottoproblemi per arrivare alla soluzione di problemi più grandi es. sviluppo di librerie] 50 25

26 Dal problema al programma Due aspetti da gestire: i dati da utilizzare la successione di operazioni da compiere 51 Dal problema al programma introdurremo la nozione di contenitore di dati come astrazione dalla nozione di zona della memoria utilizzata da un computer per i dati introdurremo i principali tipi di istruzioni descriveremo gli algoritmi mediante diagrammi di flusso, strumento per descrivere una successione di operazioni adatto all uomo e orientato alla traduzione in un linguaggio di programmazione 52 26

27 Processo di sviluppo di un algoritmo orientato alla programmazione Descriveremo i passi da seguire nella costruzione di un algoritmo, intesa come passo preliminare alla costruzione di un corrispondente programma. Il processo delineato è adatto alla programmazione in piccolo programmazione in piccolo = costruzione di programmi di dimensioni trattabili da un singolo programmatore La programmazione in grande richiede processi di sviluppo ingegnerizzati, che non tratteremo. 53 I contenitori di dati Un contenitore dati è un astrazione della nozione di area di memoria contenente dei dati, è detto anche variabile di programma. Un contenitore dati ha un tipo, che caratterizza un insieme di elementi, cioè l insieme dei valori ammessi per quel contenitore le operazioni possibili su di essi Es.: tipo intero (32 bit per ogni variabile) insieme: insieme dei numeri interi rappresentabili operazioni: +, -, *, /, ecc

28 I contenitori di dati Es. tipo BYTE Occupazione in memoria: 1 byte per variabile Operazioni possibili: +, -, (attenzione all overflow!), >, <, ==, *, / (con approssimazioni!) Numeri da 0 a [ ] 255 [ ] 55 I contenitori di dati Es. tipo BOOLEAN Occupazione in memoria: 1 byte per variabile TRUE o FALSE 0 [ ] > FALSE Qualsiasi altra rappresentazione TRUE Operazioni possibili: AND, OR, XOR, NOT Non è possibile eseguire * o /! 56 28

29 Rappresentazione grafica dei contenitori di dati pippo: intero 54 Nome del contenitore: pippo tipo : intero Contenuto = dato (appartenete al tipo di dati associato al nome, infatti 54 è un numero intero, e su di esso sono ammesse le usuali operazioni aritmetiche) 57 I contenitori di dati I linguaggi di programmazione ad alto livello (ma anche Excel e Access) prevedono la tipizzazione dei dati. I dati possono essere di tipo semplice, cioè con un solo valore, ed i tipi comunemente previsti sono: Intero Es.: Reale Es.: 1, ,133 Logico vero / falso Testo Es.: a, pippo, Mario_Rossi, casa 58 29

30 I contenitori di dati I dati possono essere di tipo strutturato, cioè contenenti più valori, ad esempio: vettori e matrici (strutture uniformi, cioè più valori dello stesso tipo) Es.: vettore di interi [2,5,7,3,12,43] record (strutture non uniformi, cioè più valori non necessariamente dello stesso tipo) Es.: studente cognome : caratteri Rossi nome : caratteri Mario matricola : intero Istruzioni Tre categorie: istruzioni di ingresso e uscita (lettura e scrittura) istruzioni aritmetico-logiche (assegnamento) istruzioni di controllo (selezione, iterazione) 60 30

31 Istruzioni Le istruzioni di ingresso / uscita permettono di acquisire dati e di presentare risultati Esempi: read a acquisisci un dato da tastiera e mettilo nel contenitore a print 'La media dei valori dati in ingresso è ', media stampa il contenuto di media preceduto da un commento 61 Istruzioni Le istruzione di assegnamento modificano lo stato di memoria, cioè i valori dei contenitori dati (detti variabili). Sono della forma: CONTENITORE = ESPRESSIONE (leggi: metti ESPRESSIONE in CONTENITORE) Es.: a = b + 3 ESPRESSIONE può essere: una costante, una variabile, un espressione vera e propria, una funzione CONTENITORE è il nome di una variabile l esecutore valuta l ESPRESSIONE e mette il valore così calcolato in CONTENITORE, sostituendone il valore precedente

32 Espressioni Le espressioni aritmetiche esprimono calcoli numerici somma, sottrazione, prodotto divisione elevamento a potenza, radice, logaritmo, esponenziale, ecc. Es.: b**2 4 * a * c Le espressioni sui caratteri modificano parole e testi. concatenazione Es.: moto&sega (risultato: motosega) 63 Espressioni Le espressioni logiche (o booleane) esprimono calcoli logici e possono quindi assumere solo i valori vero o falso. Operatori logici relazionali: confronto fra due valori, ad esempio x < y (x + 5) == y ecc. Operatori logici AND, OR, NOT, ecc. per comporre, ad es.: (x < y) AND (y < z) Un valore booleano (vero, falso) è rappresentabile con un bit. Convenzionalmente si assegna 1 a vero, 0 a falso

33 Espressioni Le espressioni di tipo booleano assumono particolare importanza perché, usate nelle istruzioni di controllo, ci permettono di prendere delle decisioni. 65 Istruzioni Le istruzioni di controllo permettono di modificare il flusso di esecuzione delle istruzioni all interno di un programma, altrimenti puramente sequenziale. Selezione if, case,... Iterazione while, repeat for Si basano sull uso di espressioni booleane Es. se x > 0, calcola la radice quadrata di x 66 33

34 Diagrammi di flusso Blocchi di elaborazione: contengono sequenze di azioni metti x+y in y metti x-1 in x 67 Diagrammi di flusso Blocchi decisionali: contengono una condizione booleana; se vera, si segue la freccia vero, se falsa si segue la freccia falso. vero x = 0 falso 68 34

35 Diagrammi di flusso Un diagramma di flusso si ottiene collegando le frecce uscenti dai blocchi di elaborazione e decisionali. 69 Simboli principali inizio o fine elaborazione decisione connessione 70 35

36 Strutture di controllo principali sequenza 71 Strutture di controllo principali selezione vero falso 72 36

37 Strutture di controllo principali Iterazione (sequenza + selezione) falso vero 73 Inizio Esempio Acquisisci a a<0? NO b = sqrt (a) Scrivi: la radice di a è <b> SI Function RadiceQuadrata; Real a,b; // Si alloca spazio in memoria per a, b Repeat Display( Dammi a ); read a; Until (a>=0) b=sqrt(a); Display( La radice di a è: <b> ) end Fine 74 37

38 Esempio di decomposizione modulare 75 38

Informatica. Traccia. Algoritmi, dati e programmi. Elaborazione di informazione. informazione. rappresentazione dell informazione (dati) dati

Informatica. Traccia. Algoritmi, dati e programmi. Elaborazione di informazione. informazione. rappresentazione dell informazione (dati) dati 1 2 Informatica Algoritmi, dati e programmi Informatica: Scienza che studia l informazione e la sua elaborazione. informazione rappresentazione dell informazione (dati) dati elaborazione dei dati tramite

Dettagli

Informatica. Informatica. Problema - soluzione. Algoritmi, dati e programmi. Introduzione ai concetti di: Distinguiamo tra: problema

Informatica. Informatica. Problema - soluzione. Algoritmi, dati e programmi. Introduzione ai concetti di: Distinguiamo tra: problema Algoritmi, dati e programmi 1 Algoritmi, dati e programmi 2 Informatica Informatica informatica informazione mezzi mezzi fisici procedure Algoritmi, dati e programmi rappresentazione dell informazione

Dettagli

Algoritmi, dati e programmi

Algoritmi, dati e programmi Algoritmi, dati e programmi 1 Scopo della lezione Introduzione ai concetti di: problema dato algoritmo linguaggio di programmazione programma diagramma di flusso 2 1 Informatica informatica informazione

Dettagli

Algoritmi, dati e programmi

Algoritmi, dati e programmi 1 Algoritmi, dati e programmi 2 Informatica Informatica: Scienza che studia l informazione e la sua elaborazione. informazione rappresentazione dell informazione (dati) dati elaborazione dei dati tramite

Dettagli

Informatica. Elaborazione di informazione

Informatica. Elaborazione di informazione Lauree triennali della Facoltà di Medicina LEZIONE 6 Algoritmi, dati e programmi 1 Elaborazione di informazione Introduzione ai concetti di: algoritmo programma dato linguaggio di programmazione diagramma

Dettagli

Algoritmi, dati e programmi

Algoritmi, dati e programmi Algoritmi, dati e programmi Laboratorio di Informatica - Sez.A Lez. T5 (teoria) L.A. Ripamonti Scopo della lezione Introduzione ai concetti di: problema dato algoritmo linguaggio di programmazione programma

Dettagli

Algoritmo PARTE A: Algoritmi, linguaggi di programmazione e programmi

Algoritmo PARTE A: Algoritmi, linguaggi di programmazione e programmi Algoritmo PARTE A: Algoritmi, linguaggi di programmazione e programmi Un algoritmo è una descrizione non ambigua di un numero finito di operazioni. 2 3 Algoritmo Esempio: Algoritmo per accedere al proprio

Dettagli

Scopo della lezione è l introduzione ai concetti di: problema, dato, algoritmo, linguaggio di programmazione, programma, diagramma di flusso.

Scopo della lezione è l introduzione ai concetti di: problema, dato, algoritmo, linguaggio di programmazione, programma, diagramma di flusso. (Algoritmi, dati e programmi. Scopo della lezione è l introduzione ai concetti di: problema, dato, algoritmo, linguaggio di programmazione, programma, diagramma di flusso. Cerchiamo prima di tutto di collocare

Dettagli

Scopo della lezione è l introduzione ai concetti di: problema, dato, algoritmo, linguaggio di programmazione, programma, diagramma di flusso.

Scopo della lezione è l introduzione ai concetti di: problema, dato, algoritmo, linguaggio di programmazione, programma, diagramma di flusso. (Algoritmi, dati e programmi. Scopo della lezione è l introduzione ai concetti di: problema, dato, algoritmo, linguaggio di programmazione, programma, diagramma di flusso. Cerchiamo prima di tutto di collocare

Dettagli

Algoritmi, dati e programmi

Algoritmi, dati e programmi 1 Algoritmi, dati e programmi 2 Informatica Informatica: Scienza che studia l informazione e la sua elaborazione. informazione rappresentazione dell informazione (dati) dati elaborazione dei dati tramite

Dettagli

Programma del corso. Elementi di Programmazione. Introduzione agli algoritmi. Rappresentazione delle Informazioni. Architettura del calcolatore

Programma del corso. Elementi di Programmazione. Introduzione agli algoritmi. Rappresentazione delle Informazioni. Architettura del calcolatore Programma del corso Introduzione agli algoritmi Rappresentazione delle Informazioni Architettura del calcolatore Reti di Calcolatori Elementi di Programmazione Algoritmi e programmi Algoritmo Sequenza

Dettagli

Problema: dati i voti di tutti gli studenti di una classe determinare il voto medio della classe.

Problema: dati i voti di tutti gli studenti di una classe determinare il voto medio della classe. Problema: dati i voti di tutti gli studenti di una classe determinare il voto medio della classe. 1) Comprendere il problema 2) Stabilire quali sono le azioni da eseguire per risolverlo 3) Stabilire la

Dettagli

Sviluppo di programmi

Sviluppo di programmi Sviluppo di programmi Per la costruzione di un programma conviene: 1. condurre un analisi del problema da risolvere 2. elaborare un algoritmo della soluzione rappresentato in un linguaggio adatto alla

Dettagli

Introduzione alla programmazione

Introduzione alla programmazione Introduzione alla programmazione Risolvere un problema Per risolvere un problema si procede innanzitutto all individuazione Delle informazioni, dei dati noti Dei risultati desiderati Il secondo passo consiste

Dettagli

o Introduzione agli algoritmi o Rappresentazione delle Informazioni o Architettura del calcolatore o Reti di Calcolatori

o Introduzione agli algoritmi o Rappresentazione delle Informazioni o Architettura del calcolatore o Reti di Calcolatori Programma del corso o Introduzione agli algoritmi o Rappresentazione delle Informazioni o Architettura del calcolatore o Reti di Calcolatori o Elementi di Programmazione Algoritmi e programmi o Algoritmo

Dettagli

Lez. 8 La Programmazione. Prof. Pasquale De Michele (Gruppo 2) e Raffaele Farina (Gruppo 1) 1

Lez. 8 La Programmazione. Prof. Pasquale De Michele (Gruppo 2) e Raffaele Farina (Gruppo 1) 1 Lez. 8 La Programmazione Prof. Pasquale De Michele (Gruppo 2) e Raffaele Farina (Gruppo 1) 1 Dott. Pasquale De Michele Dott. Raffaele Farina Dipartimento di Matematica e Applicazioni Università di Napoli

Dettagli

Informatica ALGORITMI E LINGUAGGI DI PROGRAMMAZIONE. Francesco Tura. F. Tura

Informatica ALGORITMI E LINGUAGGI DI PROGRAMMAZIONE. Francesco Tura. F. Tura Informatica ALGORITMI E LINGUAGGI DI PROGRAMMAZIONE Francesco Tura francesco.tura@unibo.it 1 Lo strumento dell informatico: ELABORATORE ELETTRONICO [= calcolatore = computer] Macchina multifunzionale Macchina

Dettagli

Sviluppo di programmi

Sviluppo di programmi Sviluppo di programmi Per la costruzione di un programma conviene: 1. condurre un analisi del problema da risolvere 2. elaborare un algoritmo della soluzione rappresentato in un linguaggio adatto alla

Dettagli

Fasi di creazione di un programma

Fasi di creazione di un programma Fasi di creazione di un programma 1. Studio Preliminare 2. Analisi del Sistema 6. Manutenzione e Test 3. Progettazione 5. Implementazione 4. Sviluppo Sviluppo di programmi Per la costruzione di un programma

Dettagli

Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale

Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale Algoritmi e Programmazione Stefano Cagnoni Il problema

Dettagli

Sviluppo di programmi

Sviluppo di programmi Sviluppo di programmi FASE 1: Dare un nome al problema partendo dall analisi del problema FASE 2: Scrivere la specifica funzionale FASE 3: Scrittura dell algoritmo FASE 3.1: Introduzione delle variabili

Dettagli

Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale

Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma Il problema di fondo Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale Algoritmi e Programmazione Stefano

Dettagli

Linguaggi, Traduttori e le Basi della Programmazione

Linguaggi, Traduttori e le Basi della Programmazione Corso di Laurea in Ingegneria Civile Politecnico di Bari Sede di Foggia Fondamenti di Informatica Anno Accademico 2011/2012 docente: Prof. Ing. Michele Salvemini Sommario Il Linguaggio I Linguaggi di Linguaggi

Dettagli

Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale

Laboratorio di Programmazione Laurea in Ingegneria Civile e Ambientale Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma Laboratorio di Laurea in Ingegneria Civile e Ambientale Algoritmi e Algebra di Boole Stefano Cagnoni Il problema di fondo Descrizione

Dettagli

Informatica Generale Andrea Corradini Gli algoritmi e la risoluzione di problemi

Informatica Generale Andrea Corradini Gli algoritmi e la risoluzione di problemi Informatica Generale Andrea Corradini 12 - Gli algoritmi e la risoluzione di problemi Sommario Che significa risolvere un problema? Algoritmi e programmi Rappresentazione di algoritmi Lo pseudocodice Primitive

Dettagli

Unità di apprendimento 6. Dal problema al programma

Unità di apprendimento 6. Dal problema al programma Unità di apprendimento 6 Dal problema al programma Unità di apprendimento 6 Lezione 1 Conosciamo gli algoritmi e i linguaggi In questa lezione impareremo: cos è un problema come affrontarlo come descrivere

Dettagli

L informazione. Bateson, Ricevere informazioni vuol dire necessariamente ricevere notizie di differenza (Es.: Luce accesa/spenta, 1/0,...

L informazione. Bateson, Ricevere informazioni vuol dire necessariamente ricevere notizie di differenza (Es.: Luce accesa/spenta, 1/0,... L informazione Diverse proposte in letteratura Bateson, Ricevere informazioni vuol dire necessariamente ricevere notizie di differenza (Es.: Luce accesa/spenta, 1/0,...) Shannon, visione probabilistica.

Dettagli

Sistemi di Elaborazione delle Informazioni

Sistemi di Elaborazione delle Informazioni Sistemi di Elaborazione delle Informazioni Algoritmi e Programmi 1 Risoluzione di un problema Il procedimento di soluzione di un problema dovrebbe essere caratterizzato da: analisi del problema e identificazione

Dettagli

Algoritmi e Programmi

Algoritmi e Programmi Algoritmi e Programmi Algoritmi e Programmi Le azioni che si compiono ogni giorno sono finalizzate alla risoluzione di problemi. Problema di elaborazione Insieme dati di partenza Risultato ricerca Algoritmi

Dettagli

Laboratorio di Informatica. Esercitazione su algoritmi e diagrammi di flusso

Laboratorio di Informatica. Esercitazione su algoritmi e diagrammi di flusso Laboratorio di Informatica Esercitazione su algoritmi e diagrammi di flusso Algoritmi, programmi e dati Algoritmo = insieme di istruzioni che indicano come svolgere operazioni complesse su dei dati attraverso

Dettagli

ELABORAZIONE DELLE INFORMAZIONI (ALGORITMI E LINGUAGGI DI PROGRAMMAZIONE)

ELABORAZIONE DELLE INFORMAZIONI (ALGORITMI E LINGUAGGI DI PROGRAMMAZIONE) 1 LEZIONE 9 ELABORAZIONE DELLE INFORMAZIONI (ALGORITMI E LINGUAGGI DI PROGRAMMAZIONE) Laboratorio di Informatica per l Educazione A. A. 2014/2015 IN SINTESI (ELABORAZIONE) Con i COMPUTER, le macchine diventano

Dettagli

Lez. 5 La Programmazione. Prof. Salvatore CUOMO

Lez. 5 La Programmazione. Prof. Salvatore CUOMO Lez. 5 La Programmazione Prof. Salvatore CUOMO 1 2 Programma di utilità: Bootstrap All accensione dell elaboratore (Bootsrap), parte l esecuzione del BIOS (Basic Input Output System), un programma residente

Dettagli

Caratteristiche di un calcolatore elettronico

Caratteristiche di un calcolatore elettronico Prof. Emanuele Papotto Caratteristiche di un calcolatore elettronico È una macchina, costituita da circuiti elettronici digitali e da componenti elettromeccaniche, ottiche e magnetiche. È velocissimo,

Dettagli

Sommario FONDAMENTI DI INFORMATICA. Definizione formale di algoritmo. Informatica e algoritmi. ALGORITMI E LINGUAGGIO PYTHON Introduzione

Sommario FONDAMENTI DI INFORMATICA. Definizione formale di algoritmo. Informatica e algoritmi. ALGORITMI E LINGUAGGIO PYTHON Introduzione Università degli Studi di Cagliari Corsi di Laurea in Ingegneria Chimica e Ingegneria Meccanica FONDAMENTI DI INFORMATICA http://www.diee.unica.it/~marcialis/fi A.A. 2017/2018 Sommario Algoritmi, linguaggi

Dettagli

Sommario Obiettivo della programmazione e ciclo di sviluppo di programmi. Programmi. Ciclo di sviluppo di programmi. Obiettivo

Sommario Obiettivo della programmazione e ciclo di sviluppo di programmi. Programmi. Ciclo di sviluppo di programmi. Obiettivo Sommario Obiettivo della programmazione e ciclo di sviluppo di programmi Istruzioni variabili e tipi Sottoprogrammi Strutture di controllo Ricorsione 1 2 Obiettivo Ciclo di sviluppo di programmi Risoluzione

Dettagli

Introduzione alla programmazione Algoritmi e diagrammi di flusso. Sviluppo del software

Introduzione alla programmazione Algoritmi e diagrammi di flusso. Sviluppo del software Introduzione alla programmazione Algoritmi e diagrammi di flusso F. Corno, A. Lioy, M. Rebaudengo Sviluppo del software problema idea (soluzione) algoritmo (soluzione formale) programma (traduzione dell

Dettagli

Dal problema a un programma comprensibile dal calcolatore. Il Progetto degli Algoritmi. Dall analisi del problema all esecuzione

Dal problema a un programma comprensibile dal calcolatore. Il Progetto degli Algoritmi. Dall analisi del problema all esecuzione Il Progetto degli Algoritmi Fondamenti di Informatica A Ingegneria Gestionale Università degli Studi di Brescia Docente: Prof. Alfonso Gerevini Dal problema a un programma comprensibile dal calcolatore

Dettagli

CAPITOLO 3 - ALGORITMI E CODIFICA

CAPITOLO 3 - ALGORITMI E CODIFICA FASI DI SVILUPPO DEL SOFTWARE Problema Idea (soluzione) Algoritmo (soluzione formale) Programma (traduzione dell algoritmo in una forma comprensibile da un elaboratore elettronico) Test (criteri di verifica)

Dettagli

Corso di Informatica di Base

Corso di Informatica di Base Corso di Informatica di Base A.A. 2011/2012 Algoritmi e diagrammi di flusso Luca Tornatore Cos è l informatica? Calcolatore: esecutore di ordini o automa Programma: insieme di istruzioni che possono essere

Dettagli

Introduzione agli Algoritmi

Introduzione agli Algoritmi Introduzione agli Algoritmi Informatica Sara Zuppiroli A.A. 2012-2013 Informatica () Introduzione agli Algoritmi A.A. 2012-2013 1 / 25 Risoluzione dei problemi Dalla descrizione del problema all individuazione

Dettagli

Teoria dell Informazione

Teoria dell Informazione Corso di Laurea Magistrale in Scienze dell Informazione Editoriale, Pubblica e Sociale Teoria dell Informazione Cosa è l informazione L informazione è qualcosa che si possiede e si può dare ad un altro

Dettagli

Il Concetto Intuitivo di Calcolatore. Esercizio. I Problemi e la loro Soluzione. (esempio)

Il Concetto Intuitivo di Calcolatore. Esercizio. I Problemi e la loro Soluzione. (esempio) Il Concetto Intuitivo di Calcolatore Elementi di Informatica e Programmazione Ingegneria Gestionale Università degli Studi di Brescia Docente: Prof. Alfonso Gerevini Variabile di uscita Classe di domande

Dettagli

La formalizzazione dell informazione: Dati e Diagrammi di Flusso

La formalizzazione dell informazione: Dati e Diagrammi di Flusso La formalizzazione dell informazione: Dati e Diagrammi di Flusso Codifica degli algoritmi Algoritmo formulato per essere comunicato tra esseri umani chiaro, sintetico e intuitivo codificato in linguaggi

Dettagli

Rappresentazione con i diagrammi di flusso (Flow - chart)

Rappresentazione con i diagrammi di flusso (Flow - chart) Rappresentazione con i diagrammi di flusso (Flow - chart) Questo tipo di rappresentazione grafica degli algoritmi, sviluppato negli anni 50, utilizza una serie di simboli grafici dal contenuto evocativo

Dettagli

Il Concetto Intuitivo di Calcolatore. Esercizio. I Problemi e la loro Soluzione. (esempio)

Il Concetto Intuitivo di Calcolatore. Esercizio. I Problemi e la loro Soluzione. (esempio) Il Concetto Intuitivo di Calcolatore Elementi di Informatica e Programmazione Ingegneria Gestionale Università degli Studi di Brescia Docente: Prof. Alfonso Gerevini Variabile di uscita Classe di domande

Dettagli

RAPPRESENTAZIONE GLI ALGORITMI NOTAZIONE PER LA RAPPRESENTAZIONE DI UN ALGORITMO

RAPPRESENTAZIONE GLI ALGORITMI NOTAZIONE PER LA RAPPRESENTAZIONE DI UN ALGORITMO RAPPRESENTAZIONE GLI ALGORITMI NOTAZIONE PER LA RAPPRESENTAZIONE DI UN ALGORITMO Rappresentazione degli algoritmi Problema Algoritmo Algoritmo descritto con una qualche notazione Programma Defne del procedimento

Dettagli

Problemi, algoritmi, calcolatore

Problemi, algoritmi, calcolatore Problemi, algoritmi, calcolatore Informatica e Programmazione Ingegneria Meccanica e dei Materiali Università degli Studi di Brescia Prof. Massimiliano Giacomin Problemi, algoritmi, calcolatori Introduzione

Dettagli

Linguaggi di Programmazione

Linguaggi di Programmazione Linguaggi di Programmazione 1 Linguaggio naturale e linguaggio macchina La comunicazione uomo-macchina avviene attraverso formalismi che assumono la forma di un linguaggio. Caratteristiche del Linguaggio

Dettagli

Fondamenti di Informatica Laurea in Ingegneria Civile e Ingegneria per l ambiente e il territorio

Fondamenti di Informatica Laurea in Ingegneria Civile e Ingegneria per l ambiente e il territorio Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma Il problema di fondo Fondamenti di Informatica Laurea in Ingegneria Civile e Ingegneria per l ambiente e il territorio Algoritmi

Dettagli

Dal Problema all Algoritmo. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni

Dal Problema all Algoritmo. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni Dal Problema all Algoritmo Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni Cosa Impareremo Informazioni e codici Definizione e soluzione di un problema Individuazione dei dati Definizione

Dettagli

Sommario Linguaggi, messaggi e comunicazione. Introduzione ai Linguaggi di Programmazione. Linguaggio (1) Linguaggio (2)

Sommario Linguaggi, messaggi e comunicazione. Introduzione ai Linguaggi di Programmazione. Linguaggio (1) Linguaggio (2) Sommario Linguaggi, messaggi e comunicazione Traduzione di programmi Interpreti e compilatori Introduzione al processo di compilazione 1 2 Linguaggio (1) Linguaggio (2) Insieme di sequenze di simboli,

Dettagli

Pag. 1. La formalizzazione dell informazione: Dati e Diagrammi di Flusso. Codifica degli algoritmi

Pag. 1. La formalizzazione dell informazione: Dati e Diagrammi di Flusso. Codifica degli algoritmi 1 Università degli studi di Parma Dipartimento di Ingegneria dell Informazione Informatica a.a. 2012/13 Informatica Facoltà di Medicina Veterinaria a.a. 2012/13 prof. Stefano Cagnoni La formalizzazione

Dettagli

Introduzione. Informatica B. Daniele Loiacono

Introduzione. Informatica B. Daniele Loiacono Introduzione Informatica B Cos è l informatica? q È la scienza che si occupa della rappresentazione dell informazione e della sua elaborazione e gestione " Si occupa dell informazione, che fa parte di

Dettagli

Lezione 8. Soluzione di un problema Problema. Soluzione di un problema. Comprensione del Problema. Analisi. Introduzione agli algoritmi

Lezione 8. Soluzione di un problema Problema. Soluzione di un problema. Comprensione del Problema. Analisi. Introduzione agli algoritmi Lezione 8 Introduzione agli algoritmi Lezione tratta dal libro: D. Sciuto, G. Buonanno, W. Fornaciari, L. Mari Introduzione ai sistemi informatici Seconda Edizione, McGraw-Hill Capitolo 2: La formalizzazione

Dettagli

Risoluzione di un problema

Risoluzione di un problema Algoritmi Risoluzione di un problema Descrizione di un problema! Individuazione di un ALGORITMO! Metodo risolutivo (progetto) Introduzione 2 Algoritmo Sequenza finita di mosse che risolve in un tempo finito

Dettagli

Algoritmi. Andrea Passerini Conoscenze informatiche e relazionali Corso di laurea in Scienze dell Ingegneria Edile

Algoritmi. Andrea Passerini Conoscenze informatiche e relazionali Corso di laurea in Scienze dell Ingegneria Edile Algoritmi Andrea Passerini passerini@dsi.unifi.it Conoscenze informatiche e relazionali Corso di laurea in Scienze dell Ingegneria Edile Elaboratore Un elaboratore o computer è una macchina digitale, elettronica,

Dettagli

Programmazione. Dipartimento di Matematica. Ing. Cristiano Gregnanin. 29 febbraio Corso di laurea in Matematica

Programmazione. Dipartimento di Matematica. Ing. Cristiano Gregnanin. 29 febbraio Corso di laurea in Matematica Programmazione Dipartimento di Matematica Ing. Cristiano Gregnanin Corso di laurea in Matematica 29 febbraio 2016 1 / 28 Linguaggi 2 / 28 Linguaggi 3 / 28 Linguaggi di alto livello Si basano su una macchina

Dettagli

Cos è la programmazione?

Cos è la programmazione? La programmazione Cos è la programmazione? Termine usato per indicare le attività che trasformano l esigenza di risolvere un Problema in un Programma, inteso come sistema informatico capace di risolvere

Dettagli

Algoritmi e Linguaggi

Algoritmi e Linguaggi Algoritmi e Linguaggi Programmi e linguaggi Un calcolatore è solo un esecutore rapidissimo di istruzioni Un programma è un insieme di istruzioni codificate in un opportuno linguaggio 2 / 21 Linguaggi e

Dettagli

Elementi di programmazione

Elementi di programmazione Fondamenti di Informatica per la Sicurezza a.a. 2003/04 Elementi di programmazione Stefano Ferrari Università degli Studi di Milano Dipartimento di Tecnologie dell Informazione Stefano Ferrari Università

Dettagli

Paolo Bison. Fondamenti di Informatica Ingegneria Meccanica Università di Padova A.A. 2008/09

Paolo Bison. Fondamenti di Informatica Ingegneria Meccanica Università di Padova A.A. 2008/09 Linguaggi procedurali Paolo Bison Fondamenti di Informatica Ingegneria Meccanica Università di Padova A.A. 2008/09 Linguaggi procedurali, Paolo Bison, FI08, 2008-09-29 p.1 Linguaggi procedurali classe

Dettagli

Il linguaggio di programmazione Python

Il linguaggio di programmazione Python Università Roma Tre Dipartimento di Matematica e Fisica Percorso Abilitante Speciale Classe A048 Matematica Applicata Corso di Informatica Il linguaggio di programmazione Python Marco Liverani (liverani@mat.uniroma3.it)

Dettagli

Computer. Capitolo 2. 05/04/2012 continuazione 1

Computer. Capitolo 2. 05/04/2012 continuazione 1 Computer Capitolo 2 05/04/2012 continuazione 1 Le prestazioni del computer Velocità delle cpu, ossia numero d istruzioni eseguite nell unità di tempo; Dimensione delle RAM; Capacità e velocità in scrittura/

Dettagli

Linguaggi, messaggi e comunicazione Traduzione di programmi Interpreti e compilatori Introduzione al processo di compilazione

Linguaggi, messaggi e comunicazione Traduzione di programmi Interpreti e compilatori Introduzione al processo di compilazione Sommario Linguaggi, messaggi e comunicazione Traduzione di programmi Interpreti e compilatori Introduzione al processo di compilazione 1 2 Linguaggio (1) Linguaggio (2) Insieme di sequenze di simboli,

Dettagli

Informatica. Come si risolve un problema?

Informatica. Come si risolve un problema? Informatica Elaborazione automatica dell informazione Esempio di elaborazione: rubrica, elenco telefonico. Ogni problema di elaborazione dell informazione è caratterizzato da: un insieme di dati di partenza

Dettagli

Sistemi di Elaborazione delle Informazioni

Sistemi di Elaborazione delle Informazioni SCUOLA DI MEDICINA E CHIRURGIA Università degli Studi di Napoli Federico II Corso di Sistemi di Elaborazione delle Informazioni Dott. Francesco Rossi a.a. 2016/2017 1 I linguaggi di programmazione e gli

Dettagli

CONCETTI FONDAMENTALI

CONCETTI FONDAMENTALI CONCETTI FONDAMENTALI Algoritmo Procedura di trasformazione di un insieme di dati iniziali in un insieme di risultati finali mediante una sequenza di istruzioni. Linguaggio di programmazione Programma

Dettagli

LA METAFORA DELL UFFICIO

LA METAFORA DELL UFFICIO LA METAFORA DELL UFFICIO Lavagna di lavoro Lavagna di programma Sportello utenti Impiegato Capo Ufficio LAVAGNA DI LAVORO Chiamiamo variabili le posizioni sulla lavagna, identificate ognuna da un nome

Dettagli

INFORmazione+autoMATICA. Perché saperne di piu? Le fasi della programmazione. Cosa intendiamo per programmazione

INFORmazione+autoMATICA. Perché saperne di piu? Le fasi della programmazione. Cosa intendiamo per programmazione INFORmazione+autoMATICA Perché saperne di piu? Calcolatore: un supporto per la rappresentazione di informazione che può: I raccogliere impressionanti quantità di dati I eseguire velocemente e con precisione

Dettagli

Programmazione I. Fondamenti di programmazione. Problemi, Algoritmi, Diagrammi di flusso

Programmazione I. Fondamenti di programmazione. Problemi, Algoritmi, Diagrammi di flusso Programmazione I Fondamenti di programmazione ( Lezione I ) Problemi, Algoritmi, Diagrammi di flusso Fabrizio Messina messina@dmi.unict.it www.dmi.unict.it/~messina Algoritmo Dato un problema, un algoritmo

Dettagli

Formalismi per la descrizione di algoritmi

Formalismi per la descrizione di algoritmi Formalismi per la descrizione di algoritmi Per descrivere in passi di un algoritmo bisogna essere precisi e non ambigui Il linguaggio naturale degli esseri umani si presta a interpret non univoche Si usano

Dettagli

Sommario Linguaggi, messaggi e comunicazione. Introduzione ai Linguaggi di Programmazione. Linguaggio. Messaggio

Sommario Linguaggi, messaggi e comunicazione. Introduzione ai Linguaggi di Programmazione. Linguaggio. Messaggio Sommario Linguaggi, messaggi e comunicazione Traduzione di programmi Interpreti e compilatori Introduzione al processo di compilazione 1 2 Linguaggio Messaggio Insieme di sequenze di simboli, le parole,

Dettagli

PROBLEMI E ALGORITMI VESPIA CATERINA LICEO CLASSICO AGLI ANGELI

PROBLEMI E ALGORITMI VESPIA CATERINA LICEO CLASSICO AGLI ANGELI PROBLEMI E ALGORITMI prof.ssa VESPIA CATERINA LICEO CLASSICO AGLI ANGELI C O N T E N U T I Problemi. Concetto di algoritmo. Caratteristiche di un algoritmo. Descrizione di algoritmi - Diagrammi di flusso.

Dettagli

Altrimenti, il M.C.D. di a e b è anche divisore di r (e.g. a=15,b=6,r=3 che è il M.C.D.)

Altrimenti, il M.C.D. di a e b è anche divisore di r (e.g. a=15,b=6,r=3 che è il M.C.D.) Elaboratore Un elaboratore o computer è una macchina digitale, elettronica, automatica capace di effettuare trasformazioni o elaborazioni sui dati digitale l informazione è rappresentata in forma numerica

Dettagli

Linguaggio Testuale. E un formalismo che consente di rappresentare gli algoritmi mediante semplici istruzioni in linguaggio «parlato»

Linguaggio Testuale. E un formalismo che consente di rappresentare gli algoritmi mediante semplici istruzioni in linguaggio «parlato» Linguaggio Testuale E un formalismo che consente di rappresentare gli algoritmi mediante semplici istruzioni in linguaggio «parlato» Delle volte viene chiamato metalinguaggio, e l algoritmo scritto tramite

Dettagli

Linguaggi di programmazione

Linguaggi di programmazione Linguaggi di programmazione Fondamenti di Informatica Daniele Loiacono Ho definito un algoritmo e adesso? Daniele Loiacono Dall algoritmo all esecuzione q Come deve essere formalizzato un algoritmo affinché

Dettagli

Risolvere un problema significa individuare un procedimento che permetta di arrivare al risultato partendo dai dati Termine algoritmo da:

Risolvere un problema significa individuare un procedimento che permetta di arrivare al risultato partendo dai dati Termine algoritmo da: Algoritmi Algoritmi Risolvere un problema significa individuare un procedimento che permetta di arrivare al risultato partendo dai dati Termine algoritmo da: http://it.wikipedia.org/wiki/al-khwarizmi Un

Dettagli

Informatica. Richiami. Diagrammi di flusso. Algoritmi, programmi e dati. Algoritmi e diagrammi di flusso. per le lauree triennali

Informatica. Richiami. Diagrammi di flusso. Algoritmi, programmi e dati. Algoritmi e diagrammi di flusso. per le lauree triennali Informatica per le lauree triennali ESERCITAZIOE 10 Algoritmi e diagrammi di flusso Richiami ESERCITAZIOE 10 ALGORITMI E DIAGRAMMI DI FLUSSO 1 ESERCITAZIOE 10 ALGORITMI E DIAGRAMMI DI FLUSSO Algoritmi,

Dettagli

Laboratorio di Programmazione

Laboratorio di Programmazione Laboratorio di Programmazione Laurea in Bioinformatica Docente: Carlo Drioli Web: www.scienze.univr.it/fol/main?ent=oi&id=39990 Programmazione: Dati Strutture di controllo Algoritmi Materiale tratto dai

Dettagli

Algoritmo. Programmazione

Algoritmo. Programmazione Introduzione agli algoritmi Paolo Bison Fondamenti di Informatica A.A. 2006/07 Università di Padova Algoritmo descrizione di come si deve eseguire un lavoro o risolvere un problema sequenza di passi/istruzioni

Dettagli

Concetti Introduttivi

Concetti Introduttivi Concetti Introduttivi Linguaggi di Programmazione http://www.dia.uniroma3.it/~roselli/ roselli@dia.uniroma3.it Credits Materiale a cura del Prof. Franco Milicchio Linguaggi di Programmazione Impartiscono

Dettagli

Sommario. Problema computazionale Sviluppo software Algoritmi. Istruzioni Sequenziali, Condizionali, Cicliche; Javascript

Sommario. Problema computazionale Sviluppo software Algoritmi. Istruzioni Sequenziali, Condizionali, Cicliche; Javascript Sommario Problema computazionale Sviluppo software Algoritmi Diagrammi di Flusso; Pseudo Codice Istruzioni Sequenziali, Condizionali, Cicliche; Javascript 1 Il Problema computazionale È computazionale

Dettagli

Introduzione alla programmazione strutturata

Introduzione alla programmazione strutturata FONDAMENTI DI INFORMATICA Prof. PIER LUCA MONTESSORO Prof. ELIO TOPPANO Facoltà di Ingegneria Università degli Studi di Udine Introduzione alla programmazione strutturata 2001 Pier Luca Montessoro, Elio

Dettagli

3. Programmi e algoritmi

3. Programmi e algoritmi 3. Programmi e algoritmi Andrea Marongiu (andrea.marongiu@unimore.it) Paolo Valente Contiene slides del corso «Fondamenti di Informatica» del Prof. Montessoro (Università degli Studi di Udine) Recall:

Dettagli

MODULO 07. La soluzione dei problemi mediante gli algoritmi

MODULO 07. La soluzione dei problemi mediante gli algoritmi MODULO 07 La soluzione dei problemi mediante gli algoritmi MODULO 07 Unità didattica 02 Impariamo a fare i diagrammi a blocchi In questa lezione impareremo: come descrivere l algoritmo risolutivo utilizzando

Dettagli

Fondamenti di Informatica

Fondamenti di Informatica Fondamenti di Informatica (L-Z) Corso di Laurea in Ingegneria Gestionale Introduzione alla Programmazione Prof. Stefano Mariani Dott. Alket Cecaj Indice Il concetto di algoritmo Algoritmo vs. programma

Dettagli

LINGUAGGI DI ALTO LIVELLO

LINGUAGGI DI ALTO LIVELLO LINGUAGGI DI ALTO LIVELLO Si basano su una macchina virtuale le cui mosse non sono quelle della macchina hardware Linguaggi di alto livello Barriera di astrazione C Fortran Modula-2 Cobol Algol Basic Ada

Dettagli

generalità concetti di base

generalità concetti di base generalità concetti di base cosa significa informatica? scienza dell informazione e l informazione giornalistica? scienza dei computer (dall inglese computer science) per i progettisti di computer? scienza

Dettagli

Corso di Informatica. Problemi ed algoritmi. Ing Pasquale Rota

Corso di Informatica. Problemi ed algoritmi. Ing Pasquale Rota Corso di Problemi ed algoritmi Ing Pasquale Rota Argomenti Problemi ed algoritmi Proprietà degli algoritmi Pseucodice Diagrammi di flusso Problemi ed algoritmi - Ing. Pasquale Rota 2 Proprietà degli algoritmi

Dettagli

Cosa è l Informatica?

Cosa è l Informatica? Cosa è l Informatica? Scienza degli elaboratori elettronici (Computer Science) Scienza dell informazione Scienza della rappresentazione, memorizzazione, elaborazione e trasmissione dell informazione Elaboratore

Dettagli

Elementi di programmazione

Elementi di programmazione Fondamenti di Informatica per la Sicurezza a.a. 2008/09 Elementi di programmazione Stefano Ferrari UNIVERSITÀ DEGLI STUDI DI MILANO DIPARTIMENTO DI TECNOLOGIE DELL INFORMAZIONE Stefano Ferrari Università

Dettagli

Agent and Object Technology Lab Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma. Fondamenti di Informatica.

Agent and Object Technology Lab Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma. Fondamenti di Informatica. Agent and Object Technology Lab Dipartimento di Ingegneria dell Informazione Università degli Studi di Parma Fondamenti di Informatica Algoritmi Michele Tomaiuolo Algoritmo Il termine algoritmo deriva

Dettagli

Sommario. Problema computazionale Sviluppo software Algoritmi. Istruzioni Sequenziali, Condizionali, Cicliche; Javascript

Sommario. Problema computazionale Sviluppo software Algoritmi. Istruzioni Sequenziali, Condizionali, Cicliche; Javascript Sommario Problema computazionale Sviluppo software Algoritmi Diagrammi di Flusso; Pseudo Codice Istruzioni Sequenziali, Condizionali, Cicliche; Javascript Il Problema computazionale È computazionale un

Dettagli