Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
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
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: 2788
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


Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
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...
Il nuovo MacBook Neo ha una memoria SSD ...
Xbox Project Helix, le prime specifiche ...
Annunci pubblicitari sulla TV quando cam...
Prezzi aumentati del 50% durante la nott...
Sconti studiati per singolo utente: Sony...
Addio alla Kia Niro EV, il crossover sar...
Apple crede nel suo iPhone Fold: la prod...
Fortnite, un nuovo listino per i pacchet...
Ecco i nuovi Sonos Play ed Era 100 SL: d...
Razer svela il futuro del gaming potenzi...
Tre robot Narwal in offerta: pulizia aut...
Gracenote denuncia OpenAI: ChatGPT addes...
Microsoft AI Tour Milano: dall'efficienz...
Asus ExpertBook Ultra: Intel Core Ultra ...
Intel presenta i processori desktop Core...
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: 04:28.


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