Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Tutti gli articoli Tutte le news

Vai al Forum
Discussione Chiusa
 
Strumenti
Old 10-06-2008, 16:45   #1
lans23
Junior Member
 
Iscritto dal: Sep 2007
Messaggi: 26
Scelta algoritmo di ordinamento

ragazzi...ho questo problema:
devo ordinare lessicograficamente un set di stringhe, la lunghezza è variabile ma data una lunghezza tutti i set devono essere lunghi uguali (per esempio tutti da 9 caratteri)

ESEMPIO:
ABBABBABA
DDKSJHAGK
ALOSHDGAA
NASBAHSJA
LOLOAHSIA
.....
lista ordinata:

ABBABBABA
ALOSHDGAA
DDKSJHAGK
LOLOAHSIA
NASBAHSJA
......
Potete consigliarmi il miglior algoritmo di ordinamento per questo problema, oltre ai soliti merge-sort e quick-sort. Sono applicabili quelli non a confronti che hanno costi O(n)????quali???
lans23 è offline  
Old 10-06-2008, 17:05   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Prova a dare un occhio al Radix Sort.
che sia "Migliore" di altri dipende molto da quanti record da ordinare hai.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline  
Old 10-06-2008, 17:22   #3
lans23
Junior Member
 
Iscritto dal: Sep 2007
Messaggi: 26
in generale si suppone siano tanti....cmq quello che volevo capire è se per questo tipo di ordinamento ci sono migliori possibilità (più efficienti) di quelle classiche come appunto il quick o il merge.
Il radix che ordina per cifra (in questo caso per lettera) usa per ogni cifra il counting-sort??? altrimenti non si spiegherebbe il tempo lineare, sarebbe un alg a confronti.
lans23 è offline  
Old 10-06-2008, 17:33   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da lans23 Guarda i messaggi
Il radix che ordina per cifra (in questo caso per lettera) usa per ogni cifra il counting-sort??? altrimenti non si spiegherebbe il tempo lineare, sarebbe un alg a confronti.
No, questo e' l'errore. L'agoritmo interno del RADIX non ordina, ma distribuisce.
Semplicemente ad ogni passo dell'algoritmo dovrai costruire 23 liste, chiamate buckets. (23 sono le possibili lettere? Sarebbe 10 per le cifre decimali volendo). Passi ognuno dei record e lo vai a piazzare nel Bucket giusto, senza ordinare alcunche'.
Ovvio che tra un passo e l'altro potrai distruggere le liste precedenti non piu' usate.
In M passi, dove M e' la lunghezza delle stringhe da ordinare, sei a posto.
L'algoritmo e' infatti

O(N*M) ed e' migliore di O(N Log(N)) se N e' grande e M piccolo, soprattutto perche' nella rappresentazione algortmica O(N Log(N)) si trascura sempre la M, poiche' si presume che un cofnronto tra due elementi costi 1.
Cosa vera se sono numeri (meglio, "oggetti" trattabili in modo atomico dalla macchina), ma falsa se sono stringhe come in questo caso.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline  
Old 10-06-2008, 18:11   #5
lans23
Junior Member
 
Iscritto dal: Sep 2007
Messaggi: 26
quindi mi converrebbe questo tipo di algoritmo...potresti postarmi una sorta di pseudocodice... non ho ben capito la distribuzione come avviene. ti ringrazio anticipatamente.
lans23 è offline  
Old 10-06-2008, 18:25   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Provo

Codice:
Sia N il numero di record ed M la lunghezza fissa di ciascun record.
La variabilita' di ciascun carattere e' A-Z, quindi 25 caratteri diversi.

Alloco un array di 25 Liste, chiamate Bucket, ciascuno associato ad un carattere

For m = 0 to M
  Buckets.Clear(); // Pulisco tutti i Bucket
  foreach string str in Records
    int questo=string[m];
         // Ovvero il carattere t-esimo del record u-esimo
    
    Bucket[questo].Add(str);
       // Ovvero aggiungo questa stringa al bucket corrispondente
  endfor
  
  Records=Bucket.Join();
      //Passo virtuale, in pratica ricostruisco di nuovo l'array di tutti
      // i record per il prossimo passo del ciclo for esterno
      // Ma in pratica non lo faro'. Semplicemente il foreach ciclera'
      //   sul contenuto dei buckets.
      // In pratica "io" farei una sorta di double buffer
      //    Con 25*2 liste
endfor
Come vedi non ci sono confronti, ma solo distribuzioni (esattamente M*N)
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 10-06-2008 alle 18:28.
gugoXX è offline  
Old 12-06-2008, 12:38   #7
lans23
Junior Member
 
Iscritto dal: Sep 2007
Messaggi: 26
si ok, questo l'ho capito però segeundo questo esempio:

ESEMPIO RECORD:

DZAH
AVVA
MLOA
ABAB
DION

e costruendo le 26 liste distribuisco al primo passo in questo modo:

liste

A->AVVA->ABAB
B
C
D->DZAH->DION
E
....
L
M->MLOA
N
....
Poi al secondo passo per distribuire la seconda lettera come faccio???....cioè io alla fine devo avere questo:

A->ABAB->AVVA
B
C
D->DION->DZAH
E
....
L
M->MLOA
N
lans23 è offline  
Old 12-06-2008, 14:10   #8
wizard1993
Senior Member
 
L'Avatar di wizard1993
 
Iscritto dal: Apr 2006
Messaggi: 22462
dentro ogni bucket ricicli ricorsivamente avendo quindi una repprentazione quale questa

a__
|a->abab
|...
|v->avva
il caso base è un bucket di un solo elemento
__________________
amd a64x2 4400+ sk939;asus a8n-sli; 2x1gb ddr400; x850 crossfire; 2 x western digital abys 320gb|| asus g1
Se striscia fulmina, se svolazza l'ammazza
wizard1993 è offline  
Old 12-06-2008, 14:28   #9
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da wizard1993 Guarda i messaggi
dentro ogni bucket ricicli ricorsivamente avendo quindi una repprentazione quale questa

a__
|a->abab
|...
|v->avva
il caso base è un bucket di un solo elemento
Puo' essere che funzioni ma il RADIX dice diverso.

Distribuisci sull'ultima lettera:
A -> AVVA, MLOA
B -> ABAB
H -> DZAH
N -> DION

Poi riconsideri tutto come se fosse di nuovo un array, facendo attenzione a prendere il contenuto di ogni bucket nel proprio ordine (mi raccomando, considera solo, non fare veramente la JOIN)
AVVA, MLOA, ABAB, DZAH, DION
svuoti le liste (ne costruisci di nuove...) E distruisci sulla terza
A -> ABAB, DZAH
O -> MLOA, DION
V -> AVVA

Poi sulla seconda
B -> ABAB
I -> DION
L -> MLOA
V -> AVVA
Z -> DZAH

Poi sulla prima
A -> ABAB, AVVA
D -> DION, DZAH
M -> MLOA

E hai finito.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 12-06-2008 alle 14:31.
gugoXX è offline  
Old 13-06-2008, 15:30   #10
lans23
Junior Member
 
Iscritto dal: Sep 2007
Messaggi: 26
ok ci dovrei essere, penso di aver capito, ti ringrazio molto per la disponibilità.
lans23 è offline  
Old 20-06-2008, 15:31   #11
lans23
Junior Member
 
Iscritto dal: Sep 2007
Messaggi: 26
ok,mi funziona....però ho provato a fare il quicksort applicato a stringhe e devo dire che è nettamente + veloce, è normale o cè qualcosa che non va nel mio radix-sort.

Paragone quick e mio:

Input: 10000 stringhe random da 7 caratteri
tempo: 0,172(mio) 0,016(quicksort)

Input: 50000 stringhe random da 7 caratteri
tempo: 17.0 (mio) 0,047(quicksort)
lans23 è offline  
Old 28-06-2008, 22:05   #12
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Ciao Ians,

potresti postare il codice del quicksort per l'ordinamento delle stringhe?
Misciu87 è offline  
Old 28-06-2008, 22:17   #13
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
Quote:
Originariamente inviato da Misciu87 Guarda i messaggi
Ciao Ians,

potresti postare il codice del quicksort per l'ordinamento delle stringhe?

http://it.wikipedia.org/wiki/Quicksort

Qui trovi di tutto e di più!
__________________
Khelidan
khelidan1980 è offline  
Old 28-06-2008, 22:22   #14
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Ci sono già andata su quel sito ma non mi è servito a nulla, io devo ordinare delle strighe prese da un file di input in linguaggio C, dovrei usare la strcmp ma ci ho provato in mille modi e nn riesco a risolvere nulla..
Misciu87 è offline  
Old 28-06-2008, 22:57   #15
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
Quote:
Originariamente inviato da Misciu87 Guarda i messaggi
Ci sono già andata su quel sito ma non mi è servito a nulla, io devo ordinare delle strighe prese da un file di input in linguaggio C, dovrei usare la strcmp ma ci ho provato in mille modi e nn riesco a risolvere nulla..
fai un 3d,posti il codice e si vede cosa sbagli,il quicksort alla fine è sempre quello

Comunque qui è ancora meglio:

http://www.algorithm-code.com/wiki/Quick_Sort#C_Code
__________________
Khelidan

Ultima modifica di khelidan1980 : 28-06-2008 alle 22:59.
khelidan1980 è offline  
Old 28-06-2008, 23:41   #16
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
lo so che è sempre quello pero' quando nella partition si fanno i confronti tra le variabili non basta fare low<high && l[high]>=prvotkey perche' io ho delle stringhe e non degli interi non basta usare <> dovrei usare la strcmp!
Misciu87 è offline  
Old 29-06-2008, 00:11   #17
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
Quote:
Originariamente inviato da Misciu87 Guarda i messaggi
lo so che è sempre quello pero' quando nella partition si fanno i confronti tra le variabili non basta fare low<high && l[high]>=prvotkey perche' io ho delle stringhe e non degli interi non basta usare <> dovrei usare la strcmp!
ripeto se apri un topic e posti il codice che non ti funziona,qualcuno sicuramente ti aiuterà
__________________
Khelidan
khelidan1980 è offline  
Old 29-06-2008, 00:16   #18
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
Ecco il codice incriminato:

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



void readsize(char *inputlist, int *length, int *size) {
	FILE *in=fopen("inputlist.txt","r");
	int i=0,j=0;
	char tmp;

	while(fscanf(in,"%c",&tmp)!=EOF && tmp!='\n') j++;
	rewind(in);
	while(fscanf(in,"%*s\n")!=EOF) i++;
	(*length)=i; (*size)=j;
	fclose(in);
}

char *readline(FILE *in,int size) {
	char *line=(char *)malloc(size*sizeof(char)), tmp;
	int i=0;

	while(i<size && fscanf(in,"%c",&line[i])!=EOF) i++;
	fscanf(in,"%c",&tmp);
	if(tmp!='\n') 
    {
		printf("Error: malformed file\n");
		return NULL;
	}

	return line;
}

char **loadlist(char *inputlist, int *length, int *size) {
	int i;
	char **list;
	FILE *in=fopen("inputlist.txt","r");
	
	readsize(inputlist,length,size);

	list=(char **)malloc((*length)*sizeof(char *));

	for(i=0; i<(*length); i++)
		list[i]=readline(in,(*size));
		
	fclose(in);

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

int partition(char **list, int p, int r) {
	int i=p, j=r, x, v;
	char *pivot;

	x=rand()%(r-p+1)+p;
	exchange(list,x,p);
	pivot=list[p];
	
	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);
	
}
char **sortlist (char **list, int p, int r) {
	
     int q,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;
	
}
Misciu87 è offline  
Old 29-06-2008, 00:17   #19
Misciu87
Member
 
Iscritto dal: Jun 2008
Messaggi: 55
ci devono essere dei problemi quando faccio p<r,j<p ecc.
Misciu87 è offline  
Old 29-06-2008, 00:31   #20
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Non è molto carino inserirsi nelle discussioni altrui e chiedere aiuto su problemi completamente diversi. Apri una nuova discussione e vedrai che riceverai più attenzione.

In ogni caso chiuso.
VICIUS è offline  
 Discussione Chiusa


Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
Dietro le quinte di The Sims 4: l'IA dei...
Nintendo aggiorna Switch 2 con Handheld ...
Componenti PC in offerta su Amazon: GPU,...
Ecobonus moto elettriche 2026: fino a 4....
Le nuove offerte Amazon, con aggiornamen...
5 motivi per comprare oggi Motorola Edge...
I produttori di memorie non vogliono inv...
VMware Hosted Private Cloud, il cloud pr...
Le cuffie per giocatori JBL Quantum 910X...
Xiaomi Watch S3 a prezzo dimezzato: 15 g...
Nothing Phone (2a) a poco più di ...
OnePlus prepara due nuovi tablet Android...
ASUS Zenbook supera MacBook Air in tutto...
Amazfit Active 2 a 71,49€ protagonista d...
Tutti gli iPhone avranno display ProMoti...
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: 12:09.


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