Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-01-2006, 14:58   #1
SCYHO
Member
 
L'Avatar di SCYHO
 
Iscritto dal: Dec 2004
Messaggi: 88
[c++]spiegazione di funzione

ciao. ki mi spiega questa funzione elimina_dispari?
Codice:
void leggi_vetint(int V[], int & n) {
cout << "\n Procedura di inserimento del vettore";
    cout << "\n Inserisci il riempimento: ";
    cin >> n;
    cout << "\n Inserisci il vettore. Solo numeri interi positivi: ";
    for (int i=0; i<n; i++) {
       cout << "\n Elemento di posizione " << i << ": ";
       cin >> V[i];
    } 
    cout << "\n Inserimento terminato.";
}    

int elimina_dispari(int V[], int & n){
    
   int el=0;
   int cont=0;
   for (int i=0; i<n; i++)
     if (V[i]%2) {
        for ( int j=i; j<n-1; j++ )
           V[j] = V[j+1];
        n--;
        cont++;
        i--;
     }  
   return cont;       
}    

void stampa_vetint(const int V [], const int n){
    if (n)
    for (int i=0; i<n; i++) {
       cout << "\n Elemento di posizione " << i << ": ";
       cout << V[i];
    } 
    else cout << "\n Il vettore e' vuoto!";
}
ke poi viene usata nel main in questo modo
Codice:
do {  
    int vettore[DIM];
    int n,ris;
    
    leggi_vetint(vettore,n);
    cout << "\n Eliminazione di tutti gli elementi dispari dal vettore.";
    ris=elimina_dispari(vettore,n);
}
grazie ciaooo
__________________
"Voi che li avete girati nei giradischi e gridati voi che li avete aspettati ascoltati bruciati e poi scordati..chi erano mai questi Beatles
MA CHI ERANO MAI QUESTI BEATLES"
SCYHO è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2006, 15:44   #2
DarkRevenge
Member
 
Iscritto dal: May 2005
Messaggi: 118
Questa funzione, come si può facilmente intuire dal nome, elimina tutti i numeri dispari dall'array passato ad essa.

I parametri passati sono il vettore V[] e la sua grandezza n (passata per indirizzo perchè il suo valore dovrà essere decrementato ogni volta che viene eliminato un elemento).
Il primo for serve a scorrere tutto il vettore. Per ogni elemento viene controllato con un if se esso è dispari, cioè dividendolo per 2 si ottiene resto 1. Se è dispari il valore verrà cancellato mediante un for che sposta tutti gli elementi indietro di una posizione nell'array a partire da quello successivo a quello da cancellare (in questo modo l'elemento da cancellare viene sovrascritto e l'array rimane compatto). Infine viene decrementata la dimensione del vettore (n) e incrementato il contatore degli elementi cancellati. Il decremento della i invece fa in modo che, se è stato cancellato un elemento, venga controllato anche quello che ha preso il suo posto, che altrimenti verrebbe saltato.
Infine la funzione restituisce il numero di elementi cancellati
DarkRevenge è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2006, 15:51   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da SCYHO
ciao. ki mi spiega questa funzione elimina_dispari?
Codice:
int elimina_dispari(int V[], int & n){
    
   int el=0;
   int cont=0;
   for (int i=0; i<n; i++)
     if (V[i]%2) {
        for ( int j=i; j<n-1; j++ )
           V[j] = V[j+1];
        n--;
        cont++;
        i--;
     }  
   return cont;       
}
grazie ciaooo
Ciao, te la spiego volentieri io.
La funzione elimina_dispari modifica l'array in modo che alla fine ci siano soltanto numeri interi pari all'interno dell'array. In pratica con il primo for verifica se ogni elemento V[i] è dispari (perché V[i]%2 dà 1 come risultato) e in quel caso "shifta" (sposta) tutti gli elementi successivi all'indietro in modo che l'array si "compatti". Alla fine rimangono solo gli elementi pari. Nota che anche il valore della variabile n (il numero degli elementi) viene scalato man mano (ed essendo n un reference, modifica la variabile passata dal chiamante).

Nonostante la funzione elimina_dispari funzioni correttamente, è poco efficiente (deve scalare ogni volta tutti gli elementi successivi).
Una funzione molto più pratica ed efficiente è questa:
Codice:
void elimina_dispari (int *v, int &n)
{
    int i, j=0;
    for (i=0; i<n; i++)
        if ((v[i] % 2) == 0)   // v[i] e` pari?
            v[j++] = v[i];
    n = j;
}
Non è più semplice così??? Penso che nessuno prenderebbe la macchina per andare dal giornalaio sotto casa o userebbe un cacciavite per piantare un chiodo! Dico bene?
Ciao.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)

Ultima modifica di andbin : 12-01-2006 alle 16:53.
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2006, 16:44   #4
SCYHO
Member
 
L'Avatar di SCYHO
 
Iscritto dal: Dec 2004
Messaggi: 88
Quote:
Originariamente inviato da andbin
Ciao, te la spiego volentieri io.
La funzione elimina_dispari modifica l'array in modo che alla fine ci siano soltanto numeri interi pari all'interno dell'array. In pratica con il primo for verifica se ogni elemento V[i] è dispari (perché V[i]%2 dà 1 come risultato) e in quel caso "shifta" (sposta) tutti gli elementi successivi all'indietro in modo che l'array si "compatti". Alla fine rimangono solo gli elementi pari. Nota che la variabile n (il numero degli elementi) viene anch'esso scalato man mano (ed essendo un reference modifica la variabile passata dal chiamante).

Nonostante la funzione elimina_dispari funzioni correttamente, è poco efficiente (deve scalare ogni volta tutti gli elementi successivi).
Una funzione molto più pratica ed efficiente è questa:
Codice:
void elimina_dispari_2 (int *v, int &n)
{
    int i, j=0;
    for (i=0; i<n; i++)
        if ((v[i] % 2) == 0)   // v[i] e` pari?
            v[j++] = v[i];
    n = j;
}
Non è più semplice??? Penso che nessuno prenderebbe la macchina per andare dal giornalaio sotto casa o userebbe un cacciavite per piantare un chiodo! Dico bene?
Ciao.

si lo so, ma è solo un lucido della professoressa...mica l'ho fatto io.

Cmq grazie ad entrambi per la spiegazione. Forse tra 6 giorni, all'esame riuscirò a combinare qualcosa.

GRAZIEEE!!
__________________
"Voi che li avete girati nei giradischi e gridati voi che li avete aspettati ascoltati bruciati e poi scordati..chi erano mai questi Beatles
MA CHI ERANO MAI QUESTI BEATLES"
SCYHO è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2006, 16:48   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da SCYHO
si lo so, ma è solo un lucido della professoressa...
Ah beh ... allora si spiega tutto ...
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
IBM Sovereign Core: la sovranità ...
Cerchi un'asciugatrice conveniente su Am...
Ayaneo Pocket Play arriverà in ri...
iPad Pro 11'' con chip M4 scende a 949€ ...
The Sims entra in una nuova era, ma l'ac...
Netflix, Disney o Prime Video: qual &egr...
Perplexity blocca la generazione di imma...
Iliad rilancia Giga 200 e Giga 250 al po...
Apre un nuovo hub di ricarica Electra pr...
Windows 11, il primo aggiornamento del 2...
L'odiata interfaccia utente di Windows 8...
Apple, Xiaomi, Motorola, Google e vivo: ...
Robot aspirapolvere a metà prezzo: Amazo...
L'AI distruggerà milioni di posti di lav...
Gli obbligazionisti di Oracle intentano ...
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: 17:32.


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