Esercitazione sugli algoritmi e la scomposizione di un problema in sotto problemi
Il problema
Immagina di voler realizzare un piccolo registratore di cassa, che prevede di calcolare il totale da pagare per ogni cliente per ogni carrello della spesa.
Ogni carrello prevede una serie di prodotti di cui sono noti: prezzo, quantità, descrizione e sconto applicato e di voler stampare l’intero scontrino con i relativi sconti a fianco di ogni prodotto.
La risoluzione di questo problema può avvenire in tanti modi differenti; il metodo più semplice è quello di suddividere il problema in sotto problemi. Ogni sotto problema, prevede lo svolgimento di un’attività specifica.
Primi Passi
Nella formulazione di una soluzione, occorre pensare a quali parti del problema è possibile associare un sotto problema, da cui appunto poi deriva un algoritmo.
Questa metodologia prevede poi di richiamare la soluzione del sotto problema quando è necessario lo svolgimento dell’attività prevista dal sotto problema.
Una proposta di soluzione è la seguente:
- Inizio
- Ripeti
- Inserimento dati
- Se sconto >0 allora
- Calcolo dell sconto
- totale =totale+p*q
- altrimenti
- totale = totale + (p-sconto)*q
- Stampa della riga dello scontrino
- Scrivi messaggio “il carrello è vuoto 1 -> si, 0 -> no”
- Leggi vuoto
- Finché carrello contiene prodotti
- Stampa del totale da pagare
- Fine
Alcune precisazioni sono necessarie: il programma termina quando nel carrello sono finiti i prodotti; inoltre lo sconto è applicabile se il prodotto è “scontato” altrimenti il prezzo unitario è pagato per intero. Poi nel calcolo del totale parziale occorre stampare tutti i dati di quel prodotto nel formato “id rigo descrizione prezzo quantità sconto totale parziale” ove l’id è il numero del rigo stampato (si conta da 1 al numero dei prodotti) per descrizione o nome prodotto), lo sconto appare sullo scontrino in valore di costo e non di percentuale.
Ad esempio se lo sconto è del 15 % su un prezzo di un prodotto pari a 30 € lo sconto applicato è € 7.5.
Nell’elenco delle operazioni, alcune rappresentate come “macro operazioni” sono introdotte delle funzioni che elaborano quelle macro operazioni e che restituiscono solo il risultato voluto.
Ad esempio la riga 5 + richiamato un sotto problema che formalmente calcolo la sconto su un singolo prodotto. Questa funzione che chiamiamo F prevede due simboli in input “_p” e “_sc” e ritorna come risultato la variabile “_sconto”.
La notazione con il prefisso “_” indica chiaramente che i dati sono generici e che non rappresentano necessariamente i dati del nostro problema, ma i dati di un generico problema di risolvere ove è previsto il calcolo dello sconto. Quelle variabili con il prefisso sono definite come “parametri formali” del sotto problema al quale corrisponde un sotto-algoritmo al quale corrisponde un sotto programma.
La riga 3 prevede l’inserimento dei dati e quindi questi dati saranno trasferiti alle variabili che appartengono al problema in un formato opportuno.
Tale sotto problema è chiamato “I” e prevede quattro parametri “_p”, “_sc”, “_q”, e “_descrizione”.
Nella riga 9 è definito un altro sotto problema per la stampa di una generica riga dello scontrino che prevede in ingresso i valori del numero di riga dello scontrino (quello definito con id), del prezzo unitario, dello sconto (in casso di assenza di sconto è ignorata la stampa di questo dato), della quantità e del totale parziale.
Tutto l’algoritmo è eseguito in una struttura ciclica condizionale (preferibilmente post condizionale) che ripete le operazioni finché nel carrello della spesa sono presenti prodotti.
Per gestire il ciclo conviene utilizzare una variabile di nome “vuoto”, tale variabile avrà il valore 1 se il carrello è vuoto, e 0 in caso contrario. L’azione di comunicare all’algoritmo se il carrello è “vuoto” è da demandare all’utente che mediante un input segnala che i prodotti sono terminati, e che è possibile calcolare il totale da pagare (righe 10,11.
L’algoritmo con la rappresentazione in flow chart è sotto riportato:
Nell’algoritmo principale lo pseudo-codice:
- Inizio
- tot =0
- vuoto =1
- id =1
- ripeti
- Inserimento(p,q,sc,descrizione)
- Se sc>0
- sconto=calcola(p,sc)
- tot=tot+(p-sconto)*q
- altrimenti
- tot=tot+p*q
- stampa(id,,p,q,sconto,descrizione)
- id=id+1
- Scrivi “Carrello vuoto ? 1-> no, 0->si “
- Leggi vuoto
- Finché vuoto=1
- scrivi “Devi pagare:”
- Scrivi tot
- Fine
Il sotto algoritmo “inserimento” è rappresentato sotto:
Lo pseudo-codice è:
- Inizio Inserimento(_p, _q, _sc, _descizione)
- Scrivi “Inserisci nell’ordine prezzo, quantità, sconto percentuale e descrizione
- Leggi _p
- Leggi _q
- Leggi _sc
- Leggi _descrizione
Il sotto algoritmo per il calcolo dello sconto è rappresentato di seguito:
Lo pseudo-codice è:
- Inizio Calcola(_p, _sc)
- _sconto = (_p * _sc)/100
- return _sconto
- Fine
Per completare il sotto algoritmo per la stampa secondo lo schema flow chart è:
Lo pseudo-codice è:
- Inizio Stampa(_id, _p, _q, _sconto, _descrizione)
- Scrivi _id , ” “, _descrizione
- Scrivi _p, ” “, _q, ” “, _sconto, ” “. _descrizione, ” “, (_p-_sconto)*_q
- Fine
La codifica in C++ sarà oggetto di una prossima esercitazione.