Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OPPO Watch X2 Mini, lo smartwatch compatto a cui non manca nulla
OPPO Watch X2 Mini, lo smartwatch compatto a cui non manca nulla
OPPO Watch X2 Mini è uno smartwatch compatto capace di offrire un'esperienza completa di monitoraggio della salute e fitness con una cassa da 43 mm che può adattarsi a qualsiasi tipo di polso, dal più grande al - soprattutto - più piccolo. Con l'architettura dual-chip e un'autonomia che può coprire due giorni con tranquillità, rappresenta la soluzione ideale per chi cerca prestazioni premium in un formato ridotto.
Xiaomi 15T Pro, è lui il nuovo best buy? La recensione
Xiaomi 15T Pro, è lui il nuovo best buy? La recensione
Dopo il recente lancio della serie Xiaomi 15T di Monaco, vi parliamo oggi della versione più performante della nuova famiglia, ovvero Xiaomi 15 T Pro. Vi raccontiamo la nostra prova nel dettaglio, spiegando perché a questo prezzo e in questa fascia, questo smartphone ha davvero senso tenerlo in seria considerazione.
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento
Acer ha ampliato la sua offerta professionale con il TravelMate P6 14 AI, un notebook ultraleggero e robusto pensato per chi lavora in mobilità. Certificato Copilot+ PC, combina design premium, autonomia elevata e piattaforma Intel Core Ultra Serie 2 con funzionalità AI, garantendo sicurezza, affidabilità e produttività per l'utenza business moderna.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-12-2003, 15: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, 17: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, 18: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, 19: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


OPPO Watch X2 Mini, lo smartwatch compatto a cui non manca nulla OPPO Watch X2 Mini, lo smartwatch compatto a cui...
Xiaomi 15T Pro, è lui il nuovo best buy? La recensione Xiaomi 15T Pro, è lui il nuovo best buy? ...
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento Acer TravelMate P6 14 AI: il Copilot+ PC sotto i...
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Scarpe che vi faranno correre alla veloc...
MOVA Z60 Ultra Roller Complete: 200€ di ...
Xiaomi SU7 si sposta da sola? Non esatta...
Cheater bannati entro 30 minuti senza ne...
Record di auto elettriche a settembre an...
In Norvegia due nuovi record: auto elett...
Linux sempre più orfano di Intel:...
Tesla conferma il bonus su Model 3: con ...
Anche Huawei prepara il suo smartphone u...
Sondaggio Steam: AMD guadagna ancora ter...
Zeekr si espande in Europa: 001, X e 7X ...
Fino a 17 sterline a telefono: il risarc...
Nintendo Switch 2 sfrutta una variante p...
AMD e OpenAI stringono un accordo strate...
Nest Cam 2K 3a gen: la videocamera da in...
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: 21:18.


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