Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla
DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla
DJI ha appena ufficializzato la serie Lito, la sua nuova gamma di droni entry-level destinata a chi si avvicina per la prima volta alla fotografia aerea. Al centro dell'annuncio ci sono due modelli ben distinti per fascia di prezzo e specifiche tecniche: DJI Lito 1 e DJI Lito X1. Entrambi si collocano sotto la soglia regolamentare dei 249 grammi, che permette di volare con requisiti burocratici più semplici rispetto ai droni più pesanti.
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi
Siamo stati a Londra per la premiazione dei Sony World Photography Awards 2026, l'evento a tema fotografia più prestigioso. Fra sorprese e novità, ne approfittiamo per fare il punto sulla fotografia contemporanea, in cui la didascalia è sempre più necessaria a cogliere il senso della quasi totalità degli scatti.
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince
L'elettrica di casa Hyundai propone una versione AWD con estetica derivata dalla famiglia N. L'abbiamo provata per diversi giorni, per scoprire tutti i dettagli e la vera autonomia in autostrada
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-12-2011, 11:39   #1
biquidus
Junior Member
 
Iscritto dal: Sep 2011
Messaggi: 9
[C++] Numeri uguali consecutivi

Ciao ragazzi. E' da un pò che sono fermo su questo problema, cioè contare se e dove sono N numeri consecutivi uguali in un array. Ora precisando che l'array è ordinato, come posso fare? ad esempio ho:

01 01 01 02 03 03 03 03 04 05

Ora facciamo finta che sono in un record e che oltre a questo campo di numeri ne ho uno con altri numeri che dovrò successivamente addizionare tra di loro, tipo:

10 15 20 10 10 20 10 20 10 15

Io devo fare in modo che quando do l'output i numeri appartenenti alla successione numerica di sopra devono essere stampati facendo la somma. Ad esempio:

Stamperò che l'utente 01 ha speso (ad esempio) 10 + 15 + 20 = 45
L'utente 02 ha speso 10
L'utente 03 ha speso 10 + 20 + 10 = 40
L'utente 04 ha speso 10
L'utente 05 ha speso 15

Non riesco a risolvere questo problema che sembra banale.. ma non lo è!
biquidus è offline   Rispondi citando il messaggio o parte di esso
Old 19-12-2011, 13:53   #2
AngeL)
Senior Member
 
L'Avatar di AngeL)
 
Iscritto dal: May 2006
Città: Salerno
Messaggi: 936
Mi vengono in mente due approcci:

1) Utilizzando un altro array dove andrai a sommare in arr[0] tutte le spese dell'utente 01, in arr[1] quelle dell'utente 02 e così via:
Codice:
//dati
int codici_cliente[TOT_RECORD] = {01, 01, 01, 02, ...};
int spese[TOT_RECORD] = {10, 15, 20, 10, ...};

int *spese_per_utente = new int[codici_cliente[TOT_RECORD-1]];

for(int i = 0; i < TOT_RECORD; i++)
{
    spese_per_utente[codici_cliente[i]-1] += spese[i];
}

// e poi, per stampare:

for(int i = 0; i < codici_cliente[TOT_RECORD-1]; i++)
{
    cout << "Utente " << i+1 << ": " << spese_per_utente[i] << endl;
}
Oppure, con un approccio più contorto, ma parsimonioso di memoria:
Codice:
//dati
int codici_cliente[TOT_RECORD] = {01, 01, 01, 02, ...};
int spese[TOT_RECORD] = {10, 15, 20, 10, ...};

int current_user = 1;
int tot = 0;
for(int i = 0; i < TOT_RECORD; i++)
{
    if(codici_cliente[i] == current_user)
    {
        tot += spese[i];
    }
    else
    {
        cout << "Utente " << current_user << ": " << tot << endl;
        tot = 0;
        current_user++;
    }
}
    cout << "Utente " << current_user << ": " << tot << endl;


p.s. mi scuso per eventuali errori formali, è un po' che non tocco il C++
AngeL) è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla DJI Lito 1 e Lito X1 recensione: i nuovi droni p...
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi Sony World Photography Awards 2026: i premiati, ...
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince Una settimana con Hyundai Ioniq 5 N-Line: divert...
Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo Recensione OPPO Find X9 Ultra: è lui il c...
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Xbox Game Pass sarà disponibile a...
La serie HONOR 600 avrà presto un...
Mova Viax 250 in prova: il robot tagliae...
Fat e-bike per tutti: sconti Engwe, pi&u...
Google conferma l'arrivo della nuova ver...
Apple ha trovato il modo per abbassare i...
OpenAI vuole tassare l'AI per dare a tut...
MacBook Air 15'' con chip M4 a 1.199€ su...
Samsung Galaxy S25 Edge 12/512GB a 854€ ...
Super offerta sul portatile gaming Acer ...
Nanotubi di carbonio più conduttivi del ...
LG OLED evo C5 48'' a 614€ e G5 83' a 3....
Ricavi record per Samsung ma la division...
TOP 7 Amazon del weekend: gli sconti al ...
Volvo e Design Week: al Volvo Studio di ...
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: 04:30.


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