Torna indietro   Hardware Upgrade Forum > Software > Programmazione

MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-10-2007, 12:38   #1
Tkx
Member
 
Iscritto dal: Mar 2006
Messaggi: 235
[C++] LIste semplici

Salve ragazzi, sto seguendo un corso di fondamenti di informatica, con relativo studio di c++ (ma di programmazione oggetti 0 spaccato)... in compenso però ci fanno studiare le liste (inserimento in testa, estrazione dal fondo, etc.). Solamente che le dispense fanno pena e sul libro c'è scritto poco quasi e niente...qualcuno di voi ha appunti, libri o grafici da consigliare?Grazie mille!
__________________
Tkx è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2007, 14:44   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Cerca su Google. Dovresti trovare quintali di documentazione.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2007, 18:18   #3
Tkx
Member
 
Iscritto dal: Mar 2006
Messaggi: 235
Purtroppo ho trovato solamente di liste concatenate
__________________
Tkx è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2007, 18:52   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Le liste esistono concatenate o doppiamente concatenate. Non esistono liste non concatenate.
Qui trovi qualcosa: http://programmazione.html.it/guide/...i-una-lista-i/
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2007, 08:01   #5
mapomapo
Senior Member
 
L'Avatar di mapomapo
 
Iscritto dal: May 2005
Città: Bari
Messaggi: 349
1 -> 2 -> 3 -> 4 -> 5 -> 6 -> ... -> NULL

questa è una semplice lista concatenata, o semplicemente "lista" nell'accezione comune. Ti dò giusto qualche imbeccata così che tu possa capire meglio la documentazione che troverai o le eventuali dispense.
Allora:

Codice:
struct elemento
{
    //PARTE INFORMATIVA FORMATA DA VARIABILI CHE VUOI

    struct elemento *next; //PUNTATORE A ELEMENTO
};
Questa è la struttura fondamentale di una lista, formata da una parte di informazioni, una sorta di "bagaglio" che vuoi portar dietro ad ogni elemento, ed una parte "ricorsiva" che è il puntatore ad una struct di tipo "elemento".
Pensa ad una banale gestione anagrafica: non sai quanta gente può entrare (non puoi stimare il massimo e allocare staticamente la memoria), quindi devi industriarti in una maniera simile:

Codice:
struct elemento
{
    char nome[20];
    char cognome[20];
    data nascita; //definisci prima una struct data con 3 interi per eleganza..

    struct elemento *next;
};
così facendo ogni elemento della lista avrà il suo nome, cognome e data di nascita, più un importantissimo puntatore al successivo elemento.

La TESTA (inizio) della lista è un puntatore di tipo elemento che punta a NULL quando inizializzato, poi ovviamente al primo, secondo, terzo...n-esimo elemento della lista.

Codice:
int main()
{
   struct elemento *testa=NULL;
}
Quando si accede alla lista dalla testa, la si scorre imponendo le condizioni sul ciclo for fino a trovare l'elemento desiderato (p.e. for(p=testa;p->nome!="abcd";p=p->next); ) e si opera direttamente sulla struct.
Al momento della creazione di un nuovo elemento dovrai allocare dinamicamente memoria il che vuol dire che, verosimilmente, utilizzerai l'operatore "new" in C++, se invece ti hanno insegnato solo la malloc() sappi che è una funzione prettamente del C e che in OOP è più comodo utilizzare le nuove implementazioni come l'operatore di cui parlo su. Per liberare memoria dovrai fare il "delete" (o se in C devi fare la free() ) e stare attento a "riattaccare" bene i vari puntatori senza mai spezzare la catena.

Spero di essere stato chiaro, è un discorso un po' a grandi linee, giusto per darti un'imbeccata.
Per far pratica dovrai sbattere la testa sul compilatore e su qualche dispensa, ma appena farai pratica sarà facile!

Vito
__________________
Si può vincere una guerra in due...o forse anche da solo. Si può estrarre il cuore anche al più nero assassino, ma è più difficile cambiare un'idea!

Ultima modifica di mapomapo : 14-10-2007 alle 08:03.
mapomapo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
HPE punta sull'IA agentica e dichiara gu...
macOS avvisa quando si incolla un comand...
Everpure ridisegna lo storage per l’IA: ...
NVIDIA RTX Remix 1.5: realizzare remaste...
Come configurare Windows 11 like a pro, ...
Windows 11 cambia finalmente la gestione...
Arianespace: lanciata la missione Amazon...
iPhone 17 escluso dalle funzioni AI più ...
Rokarolla, il trojan Android che ruba cr...
Qwen-Robot Suite: la strategia di Alibab...
Threads raggiunge 500 milioni di utenti ...
Un chip nel cervello gli restituisce la ...
NVIDIA svela la tecnologia che trasforma...
iPhone del 20° anniversario e AirPods co...
Non solo Prime: ecco le 13 offerte su Am...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 15:06.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v