Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-03-2008, 11:43   #1
pollo86
Junior Member
 
Iscritto dal: Feb 2006
Messaggi: 11
[C] ordinamento array con indici

ciao, avrei un problemino con l'ordinamento degli array...

in pratica dopo averlo ordinato ad esempio con la funzione qsort, vorrei tenere traccia dei vecchi indici degli elementi...in pratica avendo un array[6] così definito:

indici 0 1 2 3 4 5

valori 5 6 2 3 2 4

chiamo qsort() che me li ordina in questo modo:

indici 0 1 2 3 4 5

valori 2 2 3 4 5 6

mentre io vorrei ottenere una cosa simile

indici 2 4 3 5 0 1

valori 2 2 3 4 5 6


secondo voi come potrei fare ?
pollo86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 11:46   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2788
Potresti passare alla qsort un array di strutture, nella struttura metti la coppia indice/numero e poi adatti il comparator alla nuova struttura
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 11:59   #3
pollo86
Junior Member
 
Iscritto dal: Feb 2006
Messaggi: 11
e in pratica come si farebbe ?

se ho capito bene definisco una cosa del genere

Codice:
typedef struct{
     
      int indice;
      int valore;

} array;

array *R;

qsort(R, sizeof(R), cmp);
ma come faccio ad ordinarli per valori ? E la funzione comparativa come la dovrei definire ?
pollo86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 12:12   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2788
Allora, per chiarezza la struttura la chiamerei "elemento" o qualcosa del genere. Poi la sizeOf la richiami su "elemento" e infine alla qsort devi passare non un riferimento a un elemento ma il riferimento ad un array di questi.
Detto questo, la cmp dovresti averla già fatta quando hai fatto l'ordinamento normale, devi solo modificarla un po' del tipo:
Codice:
int compare (const void * a, const void * b)
{
  return ( (*(elemento*)a).valore - (*(int*)b).valore );
}
Su quest'ultimo non sono sicuro perché è un bel po' che non uso C e non ricordo se posso usare il punto "." o se devo usare le frecce "->". Comunque il ragionamento è questo...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 12:46   #5
pollo86
Junior Member
 
Iscritto dal: Feb 2006
Messaggi: 11
grazie mille....sei un genio

ci stavo sbattendo la testa per ore, mentre tu me lo risolvi in 5 secondi...

provo subito a vedere se funge
pollo86 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
Top 7 Amazon, appena aggiornata: super s...
Intel partner di Musk: ecco il ruolo con...
Nuova rimodulazione da TIM ma questa vol...
Il citofono diventa smart con una mossa:...
HONOR 600 Pro, SoC confermato in attesa ...
Il Kindle base da 16GB è in offer...
2 microonde Samsung in super offerta, co...
I 4 migliori portatili su Amazon: c'&egr...
Nutanix accelera la migrazione da VMware...
Nutanix apre ai neocloud: piattaforma mu...
Nutanix amplia la piattaforma cloud e st...
Le fotografie dell'eclissi solare e dell...
Oracle AI Database si potenzia con nuove...
Russia offline: blackout internet mobile...
Gemini, Google investe 30 milioni per la...
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:44.


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