Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-06-2008, 16:13   #1
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
[C] Quicksort ordinamento stringhe

IL progetto consiste nell'ordinare un set di stringhe prese in input da un file e restituirle ordinate in un file di output, la prima parte del codice(funzioni exchange,partition e sortlist servono per l'ordinamento le altre funzioni per il caricamento delle stringhe e quelle funzionano) il mio problema e nella funzione partition in quanto questo codice funziona con gli interi ma non con i char perche' nei confronti con <> per i char è diverso dovrei usare strcmp ma non riesco a farlo funzionare, qualcuno può aiutarmi a sistemare questa parte?
while(p<r)
{
while(j>p && strcmp(list[j],pivot)<0) j--;
while(i<r && strcmp(list[j], pivot)>=0) i++;
if(i<j)
exchange(list,i,j);
}
exchange(list,p,j);
}

Ultima modifica di Misciu87 : 02-07-2008 alle 09:04.
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2008, 11:21   #2
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Grazie per l'aiuto veramente..
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 01-07-2008, 05:45   #3
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Qualcuno mi può aiutare per favore?
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 01:52   #4
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Proprio un bel forum questo che nessuno risponde..
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 10:22   #5
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
se mi vuoi aiutare bene so no non scrivere robe a caso..
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 10:36   #6
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Non è che l'errore in questo codice è questo?

da così:
Codice:
while(p<r) 
    {	
        while(j>p && strcmp(list[j],pivot)<0) j--;
		while(i<r && strcmp(list[j], pivot)>=0) i++;
		if(i<j) 
          exchange(list,i,j);
	} 
	exchange(list,p,j);	
}
a così:
Codice:
while(p<r) 
    {	
        while(j>p && (strcmp(list[j],pivot)<0)) j--;
		while(i<r && (strcmp(list[j], pivot)>=0)) i++;
		if(i<j) 
          exchange(list,i,j);
	} 
	exchange(list,p,j);	
}
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 10:42   #7
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Questo è l'intero codice puoi aiutarmi: non cambia nulla con la modifica che mi hai detto

void exchange(char **list, int i, int j) {
char *tmp=list[i];
list[i]=list[j];
list[j]=tmp;
}

int r) {

char q,
int i;

if(p<r)
{

q=partition(list,p,r);

sortlist(list,p,q-1);
sortlist(list,q+1,r);
}
return list;
}
void printlist(char *outputlist, char **list, int length)
{
int i;
FILE *out=fopen("outputlist.txt","w");

for(i=0; i<length; i++)
fprintf(out,"%s\n",list[i]);
fprintf(out,"\n");
fclose(out);
}
int main(int argc, const char *argv[]) {

char **list;
int length,size;
time_t start, end;

if(argc!=3)
{
printf("Usage: stringsort <input list> <output list>\n");
return 1;
}

list=loadlist((char *)argv[1],&length,&size);
start=clock();

list=sortlist(list,length,size);
end=clock();

printf("%g\n",(int)(end-start)/(int)CLOCKS_PER_SEC);
printlist((char *)argv[2],list,length);

return 0;

}[/code]

Ultima modifica di Misciu87 : 03-07-2008 alle 18:20.
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 10:46   #8
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Si hai ragione: non cambia nulla, ho preso io una svista
Comunque non ho tempo ne voglia di leggere il codice che hai postato, senza offesa, però posso darti un suggerimento: perchè non inserisci dei printf(...) dentro le iterazioni così vedi cosa succede e ti è più facile risalire al problema?
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 10:57   #9
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Non c'è bisogno che leggi il codice, io so che il codice funziona per gli interi devo solo modificare la funzione partition dove c'è p<r, j<r ecc in modo che funzioni per i char..non ci sono errori nel codice, solo che nell'output non stampa le stringhe in maniera ordinata
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2008, 20:07   #10
Furla
Senior Member
 
Iscritto dal: Feb 2004
Messaggi: 1454
secondo me fai prima a riscriverlo da capo. tra l'altro non è neanche una versione tanto pulita, a vedersi.
Furla è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2008, 00:28   #11
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da Misciu87 Guarda i messaggi
non ci sono errori nel codice, solo che nell'output non stampa le stringhe in maniera ordinata
Quindi... ci sono errori nel codice.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2008, 11:32   #12
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Non potresti usare la qsort offerta dalla libreria? LINK
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2008, 14:52   #13
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Lo devo fare cosi e io so per certo che con gli interi questa versione di quicksort funziona, io devo solo cambiarlo in modo che funzioni con i char..
Misciu87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Rocket Lab ha posticipato il lancio del ...
Dalla missione Artemis IV il razzo spazi...
Una delle sonde europee di ESA Proba-3 h...
Un modder fa girare Linux su PS5: GTA V ...
MacBook Neo: nessuna sorpresa nei primi ...
La serie POCO X8 Pro è pronta al ...
Smartphone: 2026 difficile per il mercat...
Star Wars: Knights of the Old Republic R...
Huang, NVIDIA: OpenClaw ha realizzato in...
Annunciano il recupero di 4,8 milioni di...
Oggi degli ottimi auricolari Sony con ca...
Muffa in casa? Questo deumidificatore da...
Sonos Era 100: il punto d'ingresso per u...
"Non stiamo sostituendo nessuno con...
Tutti i robot in offerta ora: prezzi bas...
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: 05:59.


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