Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-02-2010, 13:43   #1
SteveVai222
Member
 
L'Avatar di SteveVai222
 
Iscritto dal: Oct 2007
Messaggi: 150
Problema con algoritmo

Salve a tutti..
dovrei implementare un algoritmo che ordini n numeri compresi tra 0 e n^2 -1 in tempo O(n) combinando il counting e il radix sort..come posso fare?!?
non mi serve in nessun linguaggio di programmazione specifico, basta in pseudocodifica..poi per "trasporlo" ci penso io..
Grazie..
SteveVai222 è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2010, 17:21   #2
:.Blizzard.:
Senior Member
 
L'Avatar di :.Blizzard.:
 
Iscritto dal: Jan 2006
Città: Perugia - San Benedetto del Tronto
Messaggi: 348
Argh ... ho visto questo esercizio qualche settimana fà ma non lo ricordo. Comunque devi utilizzare il cambiamento di base. Che libro utilizzi per studiare? Se hai il Cormen c'è scritto proprio come risolvere questo problema.
:.Blizzard.: è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2010, 18:28   #3
SteveVai222
Member
 
L'Avatar di SteveVai222
 
Iscritto dal: Oct 2007
Messaggi: 150
utilizzo introduzione agli algoritmi di thomas h. cormen
SteveVai222 è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2010, 19:04   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12966
Io conosco l'integer sort...

in pratica per numeri sufficiente piccoli riesce ad ordinarti la cosa in ordine lineare.

Praticamente crei un array A con lunghezza pari al massimo dei tuoi numeri (trovare il massimo è lineare), ed inizializzi tutte le celle a 0.

Supponedo che gli indici dell'array vadano da 1..N, per ogni elemento X del tuo array disordinato incrementi di 1 A[X].

Esempio:

Array disordinato:

D [4, 3, 2, 6, 8, 5, 3]

Il massimo è 8 per cui creo un array con 8 posizioni:

A [0, 0, 0, 0, 0, 0, 0, 0]

Comincio la scansione...

D[1] = 4
A[4] = A[4] + 1

A [0, 0, 0, 1, 0, 0, 0, 0]

D[2] = 3
A[3] = A[3] + 1

A [0, 0, 1, 1, 0, 0, 0, 0]

E così via fino a raggiungere questa posizione:

D[6] = 5
A[5] = A[5]+1

A [0, 1, 1, 1, 1, 1, 0, 1]

A questo punto l'ultimo numero è:
D[7] = 3
A[3] = A[3]+1

Per cui:

A [0, 1, 2, 1, 1, 1, 0, 1]

A questo punto si fa la scansione dell'array A e si scrivono gli indici fino a quando la casella A[X] non diventa nulla:

2, 3, 3, 4, 5, 6, 8

Ribadisco, questo algoritmo è buono per numeri sufficientemente piccoli.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2010, 20:08   #5
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Tieni, la risposta che ho dato ad un mio amico quando mi ha chiesto una cosa molto simile, solo che i numeri arrivavano a n^3.

Allora, vediamo se riesco a spiegarmi.
Diciamo che n=100. Quindi i numeri saranno da 0 a n^3-1=999999.
Il trucco consiste nell'applicare il radix sort non prendendo ogni singola cifra come colonna ma come gruppi di cifre. Visto che è n^3 dividiamo ogni numero in 3 e applichiamo il counting sort prima sulla colonna più a destra, poi quella centrale e infine a quella sulla sinistra. E così abbiamo ordinato i numeri da 0 a n^3. Ora il costo...

Il counting sort su ogni singola colonna costa theta(n+k) dove k è il numero più grande contenibile nella colonna (nel nostro caso 99). Visto che n^3 ha 3 volte il numero di cifre di n e che abbiamo diviso n^3 in 3 numeri lunghi uguali otteniamo che k=n, quindi il singolo counting sort costa theta(n). Eseguiamo 3 counting sort e otteniamo 3*theta(n) che è uguale a theta(n).
Lo stesso giochino si può ripetere con un qualsiasi n^m dove m è una costante intera.

Dubito sia tutto chiaro leggendo una mail scritta di getto, quindi chiedi pure. ^^
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2010, 01:15   #6
SteveVai222
Member
 
L'Avatar di SteveVai222
 
Iscritto dal: Oct 2007
Messaggi: 150
@ WarDuck ma l'integer sort è tipo il counting sort un po più semplice..il problema è che i numeri non sono relativamente piccoli e poi devo risolvere il problema unendo il radix e il counting sort..comunque grazie lo stesso..

@ Kenger No direi che dovrei aver capito,facciamo la prova del 9..
Praticamente il counting sort è all'interno del radix sort giusto?!?!
quindi parte il radix sort (nel nostro caso sulle ultime 3 cifre) poi parte il counting sort..e cosi per le altre due volte..è cosi??! se mi facessi anche un piccolo tabulato in pseudocodice te ne sarei molto grato!!
comunque grazie..
SteveVai222 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
6000 mAh, 5G e 108MP a meno di 200€: ecc...
FRITZ!Mesh Set 2700: Wi-Fi 7 in tutta la...
Amazfit Cheetah 2 Pro: lo smartwatch per...
Intel, focus su GPU workstation e datace...
Addio definitivo a iOS 26.4, Apple blocc...
EPYC di nuova generazione: AMD supporter...
AMD, Arm e Qualcomm scommettono su Wayve...
Intel potrebbe estendere la vita del soc...
Windows, gli aggiornamenti di aprile for...
Addio cavi perimetrali: il robot tosaerb...
Google Pixel 10 oggi proposto a soli 549...
I robot di Boston Dynamics possono inter...
Tech, gadget e accessori a meno di 5€ su...
Ford riorganizza la divisione elettrica:...
Elon Musk trasforma xAI in fornitore di ...
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: 13:56.


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