Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-12-2003, 16:40   #1
guvodepa
Senior Member
 
L'Avatar di guvodepa
 
Iscritto dal: Nov 2003
Città: MILANO
Messaggi: 1095
Liste!!!!!!!!!!!!!!!!!!!!!

ho un problema:nessu ha un programma in c++ che allohi e deallochi una lista?

anche con la progettazione .

ciao
guvodepa è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2003, 18:56   #2
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Codice:
 
#include <iostream>
#include <string>
#include <cmath>
#include <cstdio>


using namespace std;

#ifndef LIST_H
#define LIST_H

// Liste bilaterale
struct lista
{
    int data;
    lista *next; 
    lista(int Data, lista *Next)
    {
        Next = next;
        Data = data;
    } 
};

void inizializza(lista ls);
void aggiungi(lista* &ls, int n);
lista *cerca(lista *ls, int n);
void print(lista *ls);

void inizializza(lista *ls)
{
    ls = new lista(0, NULL);
}

void aggiungi(lista* &ls, int n)
{
    if(ls == NULL){ // primo elemento
        ls->data = n;
        ls->next = NULL;
        return;
    }
    while(ls->next != NULL) // ultimo elemento
        ls = ls->next;
    ls->next = new lista(n, NULL);    
}

lista *cerca(lista *ls, int n)
{
    if(ls == 0)
    return 0;
    lista* p = ls;
    while( (p->next != NULL) && (p->data != n) ){
        p = p->next;
    }   
    return p;
}

void print(lista *ls)
{
    lista *p = ls;
    while(p->next != NULL){
        cout << p->data;
        p = p->next;
    }
}
#endif
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2003, 19:56   #3
guvodepa
Senior Member
 
L'Avatar di guvodepa
 
Iscritto dal: Nov 2003
Città: MILANO
Messaggi: 1095
grazie
ma non hai la progettazione a blocchi?
guvodepa è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2003, 20:50   #4
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
In C++ non esiste un tipo “lista”, per cui dobbiamo costruire autonomamente una
serie di funzioni le quali ci permettano di effetturare delle operazioni sulle nostre
liste. In realt`a ci sono numerose librerie, fornite a corredo di ogni distribuzione
del C++, che forniscono una classe lista, ma ci sono due motivi per i quali non
ne faremo uso: `e un buon esercizio “reinventare la ruota”, cio`e costruire da zero
buona parte delle funzioni permesse sulle liste; inoltre, non abbiamo ancora le
conoscenza necessarie per affrontare lo studio di una classe complessa, come quelle
fornite con i compilatori C++. Ovviamente le liste che utilizzeremo saranno a
scopo esclusivamente didattico, nel senso che ogni loro utilizzo professionale `e
impensabile per scarsezza di flessibilit`a ed efficienza.
Nella sezione precedente abbiamo descritto una lista come costituita da elementi,
ciascuno avente una struttura formata da un campo dati e un campo che
riferisse l’elemento ad esso successivo. Cominciamo allora a costruire un elemento;
utilizzeremo, come `e ovvio, una struttura4, avente un costruttore che forzi
l’utilizzatore ad inizializzare ogni elemento creato:
struct elem {
int info;
elem* next;
elem (int Info, elem* Next) {
info = Info;
next = Next;
}
};
Si faccia bene attenzione alla struttura elem5: abbiamo un campo intero info che
contiene l’informazione della cella, che in questo caso `e un intero; in tutto il capitolo
supporremo sempre di lavorare con liste di interi, ma nulla vieta che le liste
possano contenere un qualunque tipo di dato, primitivo o derivato. Oltre all’informazione
un elemento contiene, come detto, un puntatore all’elemento a esso
successivo next; ovviamente nel caso di elemento terminale (ultimo nella lista)
tale puntatore vale 0. Infine un elemento ha un costruttore che inizializza entrambi
i campi della struttura; in tale maniera non `e possibile costruire un elemento avente
i campi fluttuanti, il che sarebbe pericoloso perch´e `e presente un campo puntatore.
Un esempio grafico di una lista `e i seguente:
0x0001
next = 0x0002
info = 7
0x0002
next = 0x0003
info = 3
0x0003
next = 0x0000
info = 4
lista = 0x0001
Il nome di una lista `e dato da un puntatore di tipo elem*, che nel nostro esempio
`e chiamato lista; il valore di esso `e l’indirizzo della prima cella. Essa d’altronde
contiene, oltre al campo informazione, anche l’indirizzo della cella successiva, e
cos`ý via fino all’ultima cella, che ha next nullo; nel grafico l’ultima cella risulta
messa a terra, per indicare la sua posizione terminale.
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Oracle NetSuite si potenzia con nuove fu...
Musica generata con l'IA: Sony lavora a ...
Cyberpunk 2077 in versione PC su smartph...
BYD si gioca un grosso jolly: pronta Rac...
Samsung annuncia l'arrivo in Italia dei ...
Offerta lancio Pixel 10a: come ottenere ...
Google presenta Pixel 10a: poche le novi...
Caos F1 2026: 14 monoposto senza omologa...
Tesla festeggia il primo Cybercab prodot...
Desktop piccolo e potente? NZXT H2 Flow ...
Polestar spinge sull'acceleratore: arriv...
Nuovo record mondiale nel fotovoltaico: ...
L'ultimo baluardo cade: fine supporto pe...
'Il mondo non ha mai visto nulla di simi...
La Commissione europea mette sotto indag...
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: 07:34.


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