Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-05-2009, 12:43   #1
tookie
Member
 
L'Avatar di tookie
 
Iscritto dal: Apr 2009
Messaggi: 50
[C]ordinamento in c

Ciao a tutti
ho un piccolo problema con questo programma c...premetto che il programma completo è molto più complesso, visto che devo fare tante altre operazioni oltre a quelle che vedete qui...perciò potrei aver dimenticato di cancellare qualcosa del codice

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

int main(int argc,int **argv[]){

int c,i;
void sort(int array[], int dim);

/*dichiarazione vettore*/
int array[c];

/*Inserisco i valori nell'array*/

for(i=0;i<=c;i++){
  array[i]=(int)argv[i+1];
}

/*ordina dal piu piccolo al piu grande*/
sort(array,c);

for (i=0; i<c; i++) {
    printf ("Il %d numero e' = %s\n",i+1,(char *)array[i]);
  }   
   

exit(0);
}

  for (i = (dim - 1); i >= 0; i--) {
    for (j = 0; j < i; j++)   {
      if (array[j] > array[i])     {
        k = array[j];
        array[j] = array[i];
        array[i] = k;
      }
    }
  }
}
Comunque il mio problema è che il metodo sort non ordina i gli interi che gli passo dalla riga di comando. Ho provato con diversi algoritmi insertionSort, bubblesort ecc ma sembra non voler andare, e mi stampa semplicemente i numeri come gli ho inseriti

$ ./nsort 2 1 4
Il 1 numero e' = 2
Il 2 numero e' = 1
Il 3 numero e' = 4

mentre ovviamente dovrebbe stampare

$ ./nsort 2 1 4
Il 1 numero e' = 1
Il 2 numero e' = 2
Il 3 numero e' = 4
tookie è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 13:04   #2
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
Ho fatto una prova su un array piccolo ed il sort funziona bene, piuttosto è quel cast a char* che usi nella printf che mi suona abbastanza bruttino (e che tra l'altro, pur compilando, si spacca a runtime con codeblocks). Sostanzialmente, lì stai utilizzando un puntatore ma non hai allocato preventivamente memoria.
Non puoi stampare semplicemente l'intero, senza castarlo a stringa ?
__________________
Il sole è giallo
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 13:07   #3
||ElChE||88
Senior Member
 
Iscritto dal: Dec 2003
Messaggi: 4907
Quote:
int main(int argc,int **argv[])
Ma che è sta roba.
||ElChE||88 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 13:19   #4
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
Quote:
Originariamente inviato da ||ElChE||88 Guarda i messaggi
Ma che è sta roba.
Effettivamente...

Inoltre, sta attento agli indici degli array. Se dichiari un array di dimensione c, gli indici effettivamente andranno da 0 a c-1. Il comportamenteo che ottieni utlizzando anche il c-esimo elemento (array[c]) è imprevedibile.
__________________
Il sole è giallo
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 13:42   #5
tookie
Member
 
L'Avatar di tookie
 
Iscritto dal: Apr 2009
Messaggi: 50
il problema è che inizialmente avevo fatto cosi

Codice:
int main(int argc,int argv[]){
..........
for (i=0; i<=c; i++)
  {
    printf ("Il %d numero e' = %d\n",i+1,array[i]);
  }   
 .......
}
solo che la stampa veniva

$ ./nsort 7 6 4 9 0 9
Il 1 numero e' = -1080998059
Il 2 numero e' = -1080998057
Il 3 numero e' = -1080998055
Il 4 numero e' = -1080998053
Il 5 numero e' = -1080998051
Il 6 numero e' = -1080998049

e sul momento la soluzione che avevo trovato era quella di fargli il cast e stamparlo come stringa....solo che come hai visto si è rifiutato di ordinare gli input
tookie è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 13:57   #6
||ElChE||88
Senior Member
 
Iscritto dal: Dec 2003
Messaggi: 4907
..
Codice:
#include <stdio.h>
#include <stdlib.h>

void sort(int *array, int length)
{
    int i, j, k;

    for (i = length - 1; i >= 0; --i)
    {
        for (j = 0; j < i; ++j)
        {
            if (array[j] > array[i])
            {
                k = array[j];
                array[j] = array[i];
                array[i] = k;
            }
        }
    }
}

int main(int argc, char** argv)
{
    int c = argc - 1, i;

    int *array = malloc(c * sizeof(int));

    for (i = 0; i < c; ++i)
    {
        array[i] = atoi(argv[i + 1]);
    }

    for (i = 0; i < c; ++i)
    {
        printf("Il %d numero e' = %d\n", i + 1, array[i]);
    }

    sort(array, c);

    for (i = 0; i < c; ++i)
    {
        printf("Il %d numero e' = %d\n", i + 1, array[i]);
    }

    free(array);
    return 0;
}
||ElChE||88 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 14:28   #7
tookie
Member
 
L'Avatar di tookie
 
Iscritto dal: Apr 2009
Messaggi: 50
grazie mille scusa ma puoi spiegarmi un attimo cosa fa questa riga?

Codice:
 free(array);
tookie è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 14:37   #8
||ElChE||88
Senior Member
 
Iscritto dal: Dec 2003
Messaggi: 4907
Quote:
Originariamente inviato da tookie Guarda i messaggi
grazie mille scusa ma puoi spiegarmi un attimo cosa fa questa riga?

Codice:
 free(array);
Serve a liberare la memoria allocata con
Codice:
int *array = malloc(c * sizeof(int));
In realtà avrei potuto anche fare
Codice:
int array[argc - 1];
ma non tutti i compilatori supportano gli array dinamici (introdotti nel C99) e visto che dichiari le variabili ad inizio funzione immagino il tuo sia tra questi...

Ultima modifica di ||ElChE||88 : 06-05-2009 alle 14:39.
||ElChE||88 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2009, 14:50   #9
tookie
Member
 
L'Avatar di tookie
 
Iscritto dal: Apr 2009
Messaggi: 50
ah ok, ancora grazie mille;-)
tookie è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Black Friday Amazon: le migliori occasio...
Il nuovo Esplora file per Windows 11 &eg...
Black Friday e Apple: qui tutte le offer...
Il CEO di Epic contro l'etichetta 'conte...
A causa di un problema durante il lancio...
Per il responsabile delle Porsche 911 e ...
Ritorno di fiamma tra Apple e Intel: gal...
Horses è stato 'bannato': l'horro...
Truffe finanziarie sui social, scatta il...
Tesla inaugura a Busto Arsizio la postaz...
Barriere autostradali fotovoltaiche: Ana...
Accordo Gruppo FS-Microsoft: l'IA dell'a...
Prezzo mai visto: le Sony WH-1000XM5 Spe...
Microsoft amplierà il suo laborat...
ECOVACS DEEBOT T30C OMNI GEN2 a 349€: co...
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: 09:20.


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