Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-01-2010, 16:42   #1
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
[C#] Lista di combinazioni

Ciao a tutti,
da un po' di giorni mi sto cimentando col C#. La mia esperienza è molto approfondita in fatto di programmazione ad oggetti, ma sono specializzato nel mondo open source (PHP, Python, Perl, ecc.).

Nel caso specifico, non riesco a creare un metodo che mi restituisca la lista di tutte le possibili combinazioni degli elementi di un array.

Ad esempio, supponiamo che io abbia la lista così ottenuta:
Codice:
Oggetto A = new Oggetto();
Oggetto B = new Oggetto();
Oggetto C = new Oggetto();
List<Oggetto> lista = new List<Oggetto>();
lista.Add(A);
lista.Add(B);
lista.Add(C);
Quello che vorrei avere adesso è una lista che contenga una sottolista per ognuna delle possibili combinazioni degli oggetti di questa lista.

Insomma, mi occorre una lista di liste ognuna delle quali è composta da n oggetti in modo da avere tutte e 8 le possibili combinazioni di quei tre oggetti:

lista[0] = {A};
lista[1] = {A, B};
lista[2] = {A, C};
lista[3] = {A, B, C};
lista[4] = {B};
lista[5] = {B, C};
lista[6] = {C};
lista[7] = {};

Immagino che il problema sia risolvibile con una funzione ricorsiva, magari sfruttando la funzionalità yield di C#, ma attualmente non riesco a risolvere questo problema.

Grazie a chiunque conosca una formula standard o voglia aiutarmi in qualche modo, considerando che ovviamente il numero di elementi non sarà sempre 3 ma un numero che potrebbe essere diverso di volta in volta.

Ultima modifica di flx2000 : 13-01-2010 alle 16:46.
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2010, 17:54   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Ti do una semplice soluzione che funziona fino a 64 elementi

Un metodo che appunto ritorna una lista di liste di Oggetto e che accetta la lista di tutti i miei possibili oggetti (fino a 64 elementi come dicevo)

public List<List<Oggetto>> Esegui(List<Oggetto> src)

dentro il body del metodo inizi a contare con un ulong da 0 a 2^N - 1
dove N e' il numero di oggetti. (Se N e' 64 appunto avarai 2^64 -1, che e' il massimo rappresentabile dagli ulong)
Ad ogni ciclo prendi il contatore, e lo consideri come numero in base 2
Cicli quindi su tutti i bit del numero. Se e' un 1 devi quindi quindi considerare l'oggetto corrispondente in src e aggiungerlo alla List<Oggetto> temporanea che restituirai ad ogni ciclo. Se e' uno 0 no.
Restituisci (con yield) la List<Oggetto> appena costruita e poi temini il ciclo.
__________________
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   Rispondi citando il messaggio o parte di esso
Old 14-01-2010, 09:32   #3
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Infatti, avevo già pensato di usare un sistema binario, in modo che il peso del bit fosse la posizione nell'array iniziale, ma so che esiste una soluzione meno meccanica e più logica che però non ricordo.
Ad ogni modo è probabile che farò così, almeno finché qualcuno saprà indicarmi l'altra strada.
Grazie!
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 14-01-2010, 14:30   #4
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Alla fine un mio collega ha trovato un algoritmo in grado di sbrogliare la matassa e io l'ho convertito nel codice C# che risolve il problema senza utilizzare le ricorsioni.

Si presuppone che oggetti sia una lista di tipo List<Oggetto> contenente tutti gli oggetti da combinare, definita come:
Codice:
List<Oggetto> oggetti = new List<Oggetto>();
Al quale siano aggiunti i vari oggetti da combinare con dei normali Add(Oggetto).

L'elenco di combinazioni possibili è quindi inteso come un insieme di liste, una per ogni possibile combinazione, ed è così definita:
Codice:
List<List<Oggetto>> combinazioni = new List<List<Oggetto>>();
A questo punto il problema si risolve in questo modo:

Codice:
// 1. Si aggiunge alla lista di combinazioni la combinazione vuota.
combinazioni.Add(new List<Oggetto>());

// 2. Si aggiunge alla lista di combinazioni una lista per ognuno degli
// elementi da combinare.
foreach (Oggetto ogg in oggetti)
{
    combinazioni.Add(new List<Oggetto> { ogg });
}

// 3. Il numero di combinazioni è 2^n, ma nell'aggiungere gli elementi
// possiamo tralasciare tutte le combinazioni che finiscono con l'ultimo
// oggetto presente nella lista "oggetti", perché non hanno mai altri
// oggetti da concatenare. Il numero di passaggi diventa quindi 2^n-n
// con n il numero di elementi in "oggetti".
int maxidx = (int)Math.Pow(2, oggetti.Count) - oggetti.Count;

// 4. Per ognuna delle combinazioni già realizzate creo una nuova
// combinazione aggiungendo alla combinazione in esame gli elementi in
// "oggetti" che abbiano un indice superiore all'ultimo elemento di questa
// combinazione.
// In questo modo non rischio di aggiungere due volte la stessa combinazione
// e grazie alla variabile maxidx non vengono eseguiti né cicli a vuoto né
// si ha bisogno di istruzioni if.
for (int i = 1; i < maxidx; i++)
{
    for (int j = oggetti.IndexOf(combinazioni[i].Last<Oggetto>()) + 1; j < oggetti.Count; j++)
    {
        combinazioni.Add(combinazioni[i].GetRange(0, combinazioni[i].Count).Concat(new List<Oggetto> { oggetti[j] }).ToList());
    }
}
Questo codice ha risolto brillantemente il problema, ma lascio aperta la "sfida" a chiunque riesca a trovare metodi alternativi per risolverlo.
Grazie a tutti.

Ultima modifica di flx2000 : 14-01-2010 alle 14:36.
flx2000 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Apple corregge una pericolosa vulnerabil...
Honda svela WN7, la prima moto elettrica...
Ford taglia altri 1.000 posti in Germani...
Apple Sports arriva in Italia: l'app gra...
Il CEO di Gearbox ai videogiocatori: Bor...
Samsung Galaxy Watch8 e Watch Ultra in o...
SMIC testa macchinari DUV sviluppati in ...
ReVanced fa marcia indietro ed elimina U...
Google Pixel Watch 3 con un super ribass...
Tornano a 135€ le Squier by Fender Strat...
Samsung userà il suo chip a 2 nm ...
Monitor gaming quasi regalati: i modelli...
Offerte Logitech da urlo su Amazon: cuff...
Reddit cambia le regole di gestione dell...
ASUS annuncia l'arrivo in Italia del mon...
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:52.


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