Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-06-2009, 16:21   #1
nalsk
Member
 
L'Avatar di nalsk
 
Iscritto dal: Jun 2009
Messaggi: 38
[C] problema funzionamento - Radix Sort -

Salve a tutti,

Sono nuovo del forum hardware upgrade, e colgo l'occasione di fare il mio primo post chiedendovi disperatamente aiuto sul funzionamento del radix sort!
Vorrei implementare l'algoritmo di ordinamento su un vettore di liste riempite random da numeri interi.
Il mio problema è il seguente: quando richiamo la funzione radix, se la utilizzo nel seguente modo:

rad=radix_sort(rad);

il compilatore mi da un errore sull'argomento che passo alla funzione, mentre sia nella mask sia nella dichiarativa ho usato list_pointer radix_sort(list_pointer ptr), che a mio avviso è compatibile con la chiamata che uso.

Se potreste mettermi almeno sulla giusta strada ve ne sarei grato, in quanto non sono sicuro di aver eseguito tutti i passaggi alla perfezione.
grazie in anticipo..

riporto il codice che ho buttato giù fino ad ora:

Codice:
#include <stdio.h>
#include <stdlib.h>

#define RADICE_SIZE 10  //GRANDEZZA RADIX
#define MAX_CIFRE 4 

#define MAX_ELEM 10   



typedef struct list_node *list_pointer;
typedef struct list_node {
        int chiave[MAX_CIFRE];
        list_pointer link;
        }lista;

void random (void);
void visrad(list_pointer ptr);
list_pointer radix_sort(list_pointer);

list_pointer rad[RADICE_SIZE];

int vettore[MAX_ELEM];

main()
{
      int i;
      
      printf("\tCreazione:\n\n");
      random();
      for(i=0;i<RADICE_SIZE;i++) {
                                 printf("\t%d",i);
                                 visrad(rad[i]);
                                 printf("\n");
                                 }
      printf("\n");
      
      for(i=0;i<MAX_ELEM;i++) printf("%5d",vettore[i]);
      
      printf("\n\n\tOrdinamento:\n\n");
      
      for(i=0;i<RADICE_SIZE;i++) rad[i]=radix_sort(rad[i]);
      
      printf("x");
      
            for(i=0;i<RADICE_SIZE;i++) {
                                 printf("\t%d",i);
                                 visrad(rad[i]);
                                 printf("\n");
                                 }
      
      fflush(stdin);getchar();
}

//------------- INSERIMENTO --------------------------------------------

void insert_rad (list_pointer *ptr,int item)
{
     list_pointer temp;
     int i,aux;
     
     temp = (lista*)malloc(sizeof(lista));
     
     for(i=0;i<MAX_CIFRE;i++) temp->chiave[i]=(int)(item/pow(10,i))%10;
     temp->link = *ptr;
     *ptr = temp;
}

//------------- INSERIMENTO --------------------------------------------

void random (void)
{
     int i,x;
     srand(time(NULL));
     for(i=0;i<MAX_ELEM;i++) {
                             vettore[i]=rand()%((int)pow(RADICE_SIZE,MAX_CIFRE));
                             x=rand()%(RADICE_SIZE);
                             insert_rad(&rad[x],vettore[i]);
                             }
     }

//------------- VISITA DELLA RADICE -------------------------------------

void visrad(list_pointer ptr)
{
     int i;
     
     printf("\t");
     for(;ptr;ptr=ptr->link) {
                             for(i=MAX_CIFRE-1;i>=0;i--)
                             printf("%d",ptr->chiave[i]);
                             printf(" ");
                             }
}

//------------- ORDINAMENTO --------------------------------------------

list_pointer radix_sort(list_pointer ptr)
{
             list_pointer davanti[RADICE_SIZE],dietro[RADICE_SIZE];
             int i,j,cifra;
             
             for(i = MAX_CIFRE-1;i>=0;i--) {
                   for(j=0;j<RADICE_SIZE;j++) davanti[j] = dietro[j] = NULL;
                   while(ptr) {
                              cifra = ptr->chiave[i];
                              if(!davanti[cifra]) davanti[cifra] = ptr;
                              else                dietro[cifra]->link = ptr;
                              dietro[cifra] = ptr;
                              ptr = ptr->link;
                              }
                              ptr = NULL;
                              for(j = RADICE_SIZE-1;j>=0;j--)
                              if(davanti[j]) {
                                            dietro[j]->link = ptr;
                                            ptr = davanti[j];
                                            }
                              }
                              return ptr;
                   }

Ultima modifica di nalsk : 15-06-2009 alle 12:01.
nalsk è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 11:30   #2
nalsk
Member
 
L'Avatar di nalsk
 
Iscritto dal: Jun 2009
Messaggi: 38
So che è una domanda banale e molti di voi non vorrebbero perdere tempo su una cosa come questa, ma purtroppo io ho provato invano tutto ciò che la mia poca esperienza mi ha insegnato. A questo punto sono al "capolinea"..

Mettiamola così: offro birra e pizza a chi mi da delucidazioni
nalsk è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:21   #3
Wing_Zero
Bannato
 
L'Avatar di Wing_Zero
 
Iscritto dal: Oct 2002
Città: Vicino Fermo Mercatino:più di 100 trattative tutte OK
Messaggi: 4651
Quote:
Originariamente inviato da nalsk Guarda i messaggi
So che è una domanda banale e molti di voi non vorrebbero perdere tempo su una cosa come questa, ma purtroppo io ho provato invano tutto ciò che la mia poca esperienza mi ha insegnato. A questo punto sono al "capolinea"..

Mettiamola così: offro birra e pizza a chi mi da delucidazioni
Ora va:
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define RADICE_SIZE 10  //GRANDEZZA RADIX
#define MAX_CIFRE 4 

#define MAX_ELEM 10   



typedef struct list_node *list_pointer;
typedef struct list_node {
        int chiave[MAX_CIFRE];
        list_pointer link;
        }lista;

void random1 (void);
void visrad(list_pointer ptr);
list_pointer radix_sort(list_pointer);

list_pointer rad[RADICE_SIZE];

int vettore[MAX_ELEM];

main()
{
      int i;
      
      printf("\tCreazione:\n\n");
      random1();
      for(i=0;i<RADICE_SIZE;i++) {
                                 printf("\t%d",i);
                                 visrad(rad[i]);
                                 printf("\n");
                                 }
      printf("\n");
      
      for(i=0;i<MAX_ELEM;i++) printf("%5d",vettore[i]);
      
      printf("\n\n\tOrdinamento:\n\n");
      
      for(i=0;i<RADICE_SIZE;i++) rad[i]=radix_sort(rad[i]);
      
      printf("x");
      
            for(i=0;i<RADICE_SIZE;i++) {
                                 printf("\t%d",i);
                                 visrad(rad[i]);
                                 printf("\n");
                                 }
      
      fflush(stdin);getchar();
}

//------------- INSERIMENTO --------------------------------------------

void insert_rad (list_pointer *ptr,int item)
{
     list_pointer temp;
     int i,aux;
     
     temp = (lista*)malloc(sizeof(lista));
     
     for(i=0;i<MAX_CIFRE;i++) temp->chiave[i]=(int)(item/pow(10,i))%10;
     temp->link = *ptr;
     *ptr = temp;
}

//------------- INSERIMENTO --------------------------------------------

void random1 (void)
{
     int i,x;
     srand(time(NULL));
     for(i=0;i<MAX_ELEM;i++) {
                             vettore[i]=rand()%((int)pow(RADICE_SIZE,MAX_CIFRE));
                             x=rand()%(RADICE_SIZE);
                             insert_rad(&rad[x],vettore[i]);
                             }
     }

//------------- VISITA DELLA RADICE -------------------------------------

void visrad(list_pointer ptr)
{
     int i;
     
     printf("\t");
     for(;ptr;ptr=ptr->link) {
                             for(i=MAX_CIFRE-1;i>=0;i--)
                             printf("%d",ptr->chiave[i]);
                             printf(" ");
                             }
}

//------------- ORDINAMENTO --------------------------------------------

list_pointer radix_sort(list_pointer ptr)
{
             list_pointer davanti[RADICE_SIZE],dietro[RADICE_SIZE];
             int i,j,cifra;
             
             for(i = MAX_CIFRE-1;i>=0;i--) {
                   for(j=0;j<RADICE_SIZE;j++) davanti[j] = dietro[j] = NULL;
                   while(ptr) {
                              cifra = ptr->chiave[i];
                              if(!davanti[cifra]) davanti[cifra] = ptr;
                              else                dietro[cifra]->link = ptr;
                              dietro[cifra] = ptr;
                              ptr = ptr->link;
                              }
                              ptr = NULL;
                              for(j = RADICE_SIZE-1;j>=0;j--)
                              if(davanti[j]) {
                                            dietro[j]->link = ptr;
                                            ptr = davanti[j];
                                            }
                              }
                              return ptr;
                   }
Correzioni:
1) rinominato la funzione random in random1 : random è una funzione già esistente nelle librerie incluse.

2) mancava l'inclusione di math.h

Se utlizzai un compilatore gcc dovrai aggiungere al termine della command line -lm per fargli linkare la libreria math.h

Ciao
Wing
Wing_Zero è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:25   #4
nalsk
Member
 
L'Avatar di nalsk
 
Iscritto dal: Jun 2009
Messaggi: 38
Quote:
Originariamente inviato da Wing_Zero Guarda i messaggi
Ora va:
grazie mille! è che questi giorni la mia testolina non sta ingranando come si deve.. a bon rendere
nalsk è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:28   #5
nalsk
Member
 
L'Avatar di nalsk
 
Iscritto dal: Jun 2009
Messaggi: 38
ora compila ma il radix non ordina.. sarà un errore nell'algoritmo di ordinamento?
nalsk è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:31   #6
Wing_Zero
Bannato
 
L'Avatar di Wing_Zero
 
Iscritto dal: Oct 2002
Città: Vicino Fermo Mercatino:più di 100 trattative tutte OK
Messaggi: 4651
Quote:
Originariamente inviato da nalsk Guarda i messaggi
ora compila ma il radix non ordina.. sarà un errore nell'algoritmo di ordinamento?
Non ho avuto tempo di vedere se l'output fosse ordinato correttamente...sicuramente è diverso dai valori base...se poi non sono ordinati correttamente non so xD
Ho passato il primo anno di università a intrecciarmi gli occhi su algoritmi di ordinamento che nn ordinavano correttamente...ora lascio il divertimento a te Detto spassionatamente nn ho alcuna voglia
Torno a finire di programmare un webservice in java.

Ciao
Wing
Wing_Zero è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:38   #7
nalsk
Member
 
L'Avatar di nalsk
 
Iscritto dal: Jun 2009
Messaggi: 38
Quote:
Originariamente inviato da Wing_Zero Guarda i messaggi
Non ho avuto tempo di vedere se l'output fosse ordinato correttamente...sicuramente è diverso dai valori base...se poi non sono ordinati correttamente non so xD
Ho passato il primo anno di università a intrecciarmi gli occhi su algoritmi di ordinamento che nn ordinavano correttamente...ora lascio il divertimento a te Detto spassionatamente nn ho alcuna voglia
Torno a finire di programmare un webservice in java.

Ciao
Wing
grazie mille lo stesso.. buon lavoro
nalsk è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
La NASA sta provando il Divergent Deploy...
Fidanzarsi con l'IA non è cos&igr...
AI Overviews: quando il riassunto &egrav...
Il circuito segreto di Apple finisce a W...
Disastro Meta: l'azienda elimina il rico...
Google Gemini non va: centinaia di segna...
Neural Dawn mostra il futuro del gaming ...
Telegram torna su Apple Watch con un'app...
Da oggi si può acquistare Amazon ...
Windows 11 è più veloce: implementati il...
Ritornano gli auricolari con il cavo: Te...
Insta360 Luna Ultra: ecco il debutto del...
BOOX Go 6 Gen II ufficiale: ora si scriv...
BYD sfida Tesla con un piano da 2 miliar...
La corsa ai datacenter passa dalla stamp...
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: 22:11.


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