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 09-11-2012, 17:46   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] Algoritmi di ordinamento...dubbi

Ho provato a fare un algoritmo di ordinamento di un array di interi...in ordine crescente..
non funzionava bene...e ho cercato un pò sul web...
...ho trovato questo:
Codice:
void ordina(vettore v,int d)
{
int i,j,mem,n;
n=d;
for(i=0;i<d;i++)
  {
   for(j=0;j<n-1;j++)
   {
   if(v[j]>v[j+1])
    {
     mem=v[j];
     v[j]=v[j+1];
     v[j+1]=mem;
    }
   }
   n=n-1;
  }
}
...e ho notato che il mio errore è quello sul for...cioè io ne mettevo uno solo, mentre qua ce ne sono due!
Non ho capito il perchè...qualcuno sa spiegarmelo?!
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 09-11-2012, 19:53   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Supponi che il tuo array di partenza sia questo:
Codice:
[5, 4, 3, 2, 1, 0]
Con un solo ciclo come lo hai scritto tu succede questo.

Il for fa il suo primo giro. Gli elementi 0 e 1 sono confrontati tra di loro. Il 5 è maggiore di 4 quindi i due elementi sono scambiati di posto. A questo punto hai l'array ordinato in questo modo:
Codice:
[4, 5, 3, 2, 1, 0]
Il for non ha ancora terminato quindi continua confrontando gli elementi 1 e 2. Anche questa volta 5 è maggiore di 3 quindi i due sono scambiati. La stessa cosa succederà per il resto dei cicli. 5 è il valore più grande dell'array e verrà spostato di 1 posizione verso destra ad ogni giro del for.

Una volta terminati gli n-1 giri il 5 si trova nella giusta posizione a destra.
Codice:
[4, 3, 2, 1, 0, 5]
Il resto degli elementi però è rimasto nell'ordine di prima che è sbagliato quindi non hai ancora finito di ordinare.

Se provi a lanciare un'altra volta il for sarà il 4 ad essere spostato verso destra fino a che non arriverà nella giusta posizione. Essendoci n elementi per essere sicuro che tutti siano nella giusta posizione devi ripetere il tuo for n-1 volte.
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2012, 11:58   #3
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da VICIUS Guarda i messaggi
Supponi che il tuo array di partenza sia questo:
Codice:
[5, 4, 3, 2, 1, 0]
Con un solo ciclo come lo hai scritto tu succede questo.

Il for fa il suo primo giro. Gli elementi 0 e 1 sono confrontati tra di loro. Il 5 è maggiore di 4 quindi i due elementi sono scambiati di posto. A questo punto hai l'array ordinato in questo modo:
Codice:
[4, 5, 3, 2, 1, 0]
Il for non ha ancora terminato quindi continua confrontando gli elementi 1 e 2. Anche questa volta 5 è maggiore di 3 quindi i due sono scambiati. La stessa cosa succederà per il resto dei cicli. 5 è il valore più grande dell'array e verrà spostato di 1 posizione verso destra ad ogni giro del for.

Una volta terminati gli n-1 giri il 5 si trova nella giusta posizione a destra.
Codice:
[4, 3, 2, 1, 0, 5]
Il resto degli elementi però è rimasto nell'ordine di prima che è sbagliato quindi non hai ancora finito di ordinare.

Se provi a lanciare un'altra volta il for sarà il 4 ad essere spostato verso destra fino a che non arriverà nella giusta posizione. Essendoci n elementi per essere sicuro che tutti siano nella giusta posizione devi ripetere il tuo for n-1 volte.
Perfetto..thanks!!

Inviato dal mio GT-I9003 usando Tapatalk
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2012, 00:26   #4
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da coffe_killer Guarda i messaggi
scusate ma xke porsi il problema di come ordinare un array qnd ci sono algoritmi di ordinamento già fatti e testati da usare?
a scopo didattico!!! e per lo stesso motivo per cui ancora i bimbi imparano le addizioni a mano anche se esiste la calcolatrice!
mistergks è 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...
Arianespace potrebbe lanciare il primo r...
Google Pixel 10a disponibile al prezzo m...
Microsoft Copilot nei guai: email riserv...
AOC a 399€ su Amazon: QD-OLED 240 Hz e 0...
La Cina ha recuperato dal mare il primo ...
Boeing CST-100 Starliner: la NASA rende ...
hiop e TaDa uniscono le forze per trasfo...
Thermal Grizzly mostra il Ryzen 7 9850X3...
AMD Ryzen 'Olympic Ridge' Zen 6 per desk...
Donald Trump renderà pubbliche in...
Prezzo mai visto da mesi: ECOVACS DEEBOT...
Non solo S26, Samsung sta per lanciare a...
Windows 11 avrà a breve uno Speed...
Ask Intel: l'assistente IA che ti aiuta ...
Nasce Freedom.gov: il portale USA per ag...
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: 00:04.


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