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 15-07-2010, 15:07   #1
Vincenzoflaminio
Member
 
Iscritto dal: Jul 2006
Messaggi: 96
[C] Algoritmo ordinamento

Salve , dovrei ordinare una struct ma non so come passarla nella function che ordina i parmetri.
Il mio problema sta nell 'ordinare in ordine decrescente di vittorie le squadre, e stamparne i nomi .
Avevo scritto questo codice che mi permette di ordinare le vottorie della squadra essendo solo un array ad entrare come argomento e copiando i dati strutturati in un array semplice:
Codice:
struct _squadra
{
   int numero /*nome della squadra identificata da un numero */;
   int numvittoriesquadra;
       };
       typedef struct _squadra Squadra;

 void order_ins (int array[], int n)
{
     int i,j;
     int el_da_ins;
     j=j-i;
     for (i=1;i<n;i++)
     {
         el_da_ins=array[i];
         j= i-1;
     while (j>=0 && el_da_ins < array[j])
     {
           array[j+1] = array[j];
           j--;
           }
           array[j+1] = el_da_ins;
           }

main 
{
/*copio le vittorie in un array /*
for(i = 0; i <8; i++)
 { array_squadra[i].numvittoriesquadra = numvittoriesquadra[i];}
/* chiamata all'array
order_ins(numvittoriesquadra,lung_numvittorie);
Il problema è che quando vado a fare il printf ho ordinato le vittorie delle squadre ma non i nomi..
Vincenzoflaminio è offline   Rispondi citando il messaggio o parte di esso
Old 15-07-2010, 19:05   #2
Rsk
Senior Member
 
L'Avatar di Rsk
 
Iscritto dal: Dec 2006
Messaggi: 314
Quote:
Originariamente inviato da Vincenzoflaminio Guarda i messaggi
Salve , dovrei ordinare una struct ma non so come passarla nella function che ordina i parmetri.
Il mio problema sta nell 'ordinare in ordine decrescente di vittorie le squadre, e stamparne i nomi .
Avevo scritto questo codice che mi permette di ordinare le vottorie della squadra essendo solo un array ad entrare come argomento e copiando i dati strutturati in un array semplice:
Codice:
struct _squadra
{
   int numero /*nome della squadra identificata da un numero */;
   int numvittoriesquadra;
       };
       typedef struct _squadra Squadra;

 void order_ins (int array[], int n)
{
     int i,j;
     int el_da_ins;
     j=j-i;
     for (i=1;i<n;i++)
     {
         el_da_ins=array[i];
         j= i-1;
     while (j>=0 && el_da_ins < array[j])
     {
           array[j+1] = array[j];
           j--;
           }
           array[j+1] = el_da_ins;
           }

main 
{
/*copio le vittorie in un array /*
for(i = 0; i <8; i++)
 { array_squadra[i].numvittoriesquadra = numvittoriesquadra[i];}
/* chiamata all'array
order_ins(numvittoriesquadra,lung_numvittorie);
Il problema è che quando vado a fare il printf ho ordinato le vittorie delle squadre ma non i nomi..
Passi un puntatore a struttura
Codice:
void sort( Squadra * s);
per accedere ai campi devi fare
Codice:
int num = s->numero
__________________
Athlon64 x2 5600 - AsRock ALiveNF5eSata2+ - kingston 2GB ddr2 800 - GeForce 8800gts 320MB

Ultima modifica di Rsk : 15-07-2010 alle 19:10.
Rsk è offline   Rispondi citando il messaggio o parte di esso
Old 15-07-2010, 20:40   #3
Vincenzoflaminio
Member
 
Iscritto dal: Jul 2006
Messaggi: 96
Grazie ! modificato il codice ora :
Codice:
void order_ins (Squadra *s, int n)
{
     int i,j;
     int el_da_ins;
     j=j-i;
     for (i=1;i<n;i++)
     {
         el_da_ins=(s+i)->numvittoriesquadra;
         j= i-1;
     while (j>=0 && el_da_ins < (s+j)->numvittoriesquadra)
     {
           (s+j+1)->numvittoriesquadra = (s+j)->numvittoriesquadra;
           (s+j+1)->numero = (s+j)->numero;
           j--;
           }
           (s+j+1)->numvittoriesquadra = el_da_ins;
           }
}
nessun problema al compilatore ma alla schermata a video ho i seguenti risultati :
Array non ordinato
squadra: n =8 vittorie = 0
squadra: n =9 vittorie = 1
squadra: n =10 vittorie = 0
squadra: n =11 vittorie = 2
squadra: n =12 vittorie = 0
squadra: n =13 vittorie = 1
squadra: n =14 vittorie = 0
squadra: n =15 vittorie = 3
Squadre In ordine Crescente di vittoria
squadra: n =8 vittorie = 0
squadra: n =9 vittorie = 0
squadra: n =9 vittorie = 0
squadra: n =9 vittorie = 0
squadra: n =9 vittorie = 1
squadra: n =11 vittorie = 1
squadra: n =11 vittorie = 2
squadra: n =15 vittorie = 3

pare che mentre le vittorie si ordino c'è qualche problema con array_squadra.numero
Vincenzoflaminio è 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...
Sony non vuole aumentare il prezzo della...
Energia geotermica: la (costosa) rispost...
MG ha già venduto 1 milione di au...
"Something Big Is Happening" —...
Renault chiude il 2025 con una perdita r...
Le 34 migliori offerte Amazon di oggi: T...
Amazfit T-Rex Ultra 2 arriva su Amazon: ...
Meta chiude messenger.com: da aprile 202...
Il paradosso dell'IA: aumenta la produtt...
Oltre 2 TB di dati su un foglio A4: &egr...
Turboden realizza la più grande p...
SEGA pronta al debutto del misterioso 'S...
Microsoft ce l'ha fatta: adesso il 100% ...
Cuffie Hi-Res eleganti, con ANC e 100 or...
Processo a Meta, Zuckerberg difende Inst...
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: 15:47.


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