Torna indietro   Hardware Upgrade Forum > Software > Programmazione

GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
Il Gigabyte Gaming A16 offre un buon equilibrio tra prestazioni e prezzo: con Core i7-13620H e RTX 5060 Laptop garantisce gaming fluido in Full HD/1440p e supporto DLSS 4. Display 165 Hz reattivo, buona autonomia e raffreddamento efficace; peccano però le USB e la qualità cromatica del pannello. Prezzo: circa 1200€.
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-10-2014, 10:44   #1
xp2400
Senior Member
 
Iscritto dal: Mar 2004
Città: RoMaNoVeNeTo
Messaggi: 756
[VBA] permutazioni con ripetizioni ma con limite alle ripetizioni

Ho un array di N Elementi (es A, B, C, D) e voglio estrarre tutte le permutazioni possibili (CLASSE) es = 3.

AAA
AAB
AAC
AAD
ABB
ABC
ABD
ACD..
..
DDD
notare che ABA = AAB e scompare dall'elenco
il codice qui sotto fa egregiamente il suo lavoro (trovato in rete.





Public Function CombinazioniConRipetizione(ByVal arrayElementi As Variant, ByVal Classe As Byte) As Collection

Dim LC As New Collection
If UBound(arrayElementi) = 0 Then
Set CombinazioniConRipetizione = LC
End If
If Classe = 0 Then
Set CombinazioniConRipetizione = LC
End If
Dim aP() As Integer
ReDim aP(Classe - 1)
Dim i As Integer
Dim j As Integer
Dim C As String
Dim cnt As Integer


Do

C = ""
For i = 0 To UBound(aP)
C = C & arrayElementi(aP(i))
Next i
Application.StatusBar = "Sto creando la Combinazione " & LC.Count & "/" & MaxCombinazioni & "-->" & C
DoEvents

cnt = 0
For i = UBound(aP) To 0 Step -1
If aP(i) = UBound(arrayElementi) Then
cnt = cnt + 1
If cnt = UBound(aP) + 1 Then Exit Do
Else
aP(i) = aP(i) + 1
For j = 0 To UBound(aP)
If i < j Then aP(j) = aP(i)
Next
Exit For
End If
Next i
Loop

Set CombinazioniConRipetizione = LC
End Function

a questo punto vi chiedo: E' possibile limitare il numero di ripetizioni di ogni singolo elemento dell'array a N volte?
ad esempio se pongo N = 2, le permutazioni (AAA e BBB e CCC e DDD) non vengono calcolate....

tenete presente che sto lavorando con classi > 10.. e il numero di combinazioni sale col fattoriale...
__________________
Acer m5500 (Q6600,4MB) Sapphire Ati 3850, Logitech Performance MX, Tastiera Logitech G15, Epson bx 310 FN, QNAP 419p+, WDTVLIVE, Harmony One

Ultima modifica di xp2400 : 28-10-2014 alle 08:23.
xp2400 è offline   Rispondi citando il messaggio o parte di esso
Old 27-10-2014, 14:20   #2
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Per favore indenta il codice quando posti sul forum.

Puoi utilizzare questa funzione (non testata) per contare il numero di ripetizioni e scartare quindi le combinazioni che non ti interessano:
Codice:
Public Function maxNumRipetizioni(arrayElementi As Variant, aP() As Integer) As Integer
	Dim i	As Integer
	Dim p	As Integer
	Dim c()	As Integer
	Dim m	As Integer
	ReDim c(UBound(arrayElementi))
	For i = 0 To UBound(aP)
		p = aP(i)
		c(p) = c(p) + 1
		If c(p) > m Then m = c(p)
	Next i
	maxNumRipetizioni = m
End Function
Se arrayElementi è grande conviene allocare c all'esterno e prevedere un ulteriore ciclo di pulizia nella funzione.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2014, 08:22   #3
xp2400
Senior Member
 
Iscritto dal: Mar 2004
Città: RoMaNoVeNeTo
Messaggi: 756
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Per favore indenta il codice quando posti sul forum.

Puoi utilizzare questa funzione (non testata) per contare il numero di ripetizioni e scartare quindi le combinazioni che non ti interessano:
Codice:
Public Function maxNumRipetizioni(arrayElementi As Variant, aP() As Integer) As Integer
	Dim i	As Integer
	Dim p	As Integer
	Dim c()	As Integer
	Dim m	As Integer
	ReDim c(UBound(arrayElementi))
	For i = 0 To UBound(aP)
		p = aP(i)
		c(p) = c(p) + 1
		If c(p) > m Then m = c(p)
	Next i
	maxNumRipetizioni = m
End Function
Se arrayElementi è grande conviene allocare c all'esterno e prevedere un ulteriore ciclo di pulizia nella funzione.
Grazie.
Però mi serve qualcosa che scarti la combinazione che supera max ripetizioni durante la generazione,non dopo. Questo perchè la collection in VBA non supera circa 330k item.. e io lo supero abbondantemente...
__________________
Acer m5500 (Q6600,4MB) Sapphire Ati 3850, Logitech Performance MX, Tastiera Logitech G15, Epson bx 310 FN, QNAP 419p+, WDTVLIVE, Harmony One
xp2400 è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2014, 08:30   #4
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Si avevo capito, basta che metti il codice che genera la combinazione all'interno di un if:
Codice:
If maxNumRipetizioni(arrayElementi, aP) < valore Then
  C = ""
  For i = 0 To UBound(aP)
    C = C & arrayElementi(aP(i))
  Next i
  Application.StatusBar = "Sto creando la Combinazione " & LC.Count & "/" & MaxCombinazioni & "-->" & C
End If
PS.
Comunque nella tua routine non usi mai la collection e ci sono alcune istruzioni inutili, forse ci stai ancora lavorando?
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Lapt...
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
L'ex CEO di Intel avverte: la bolla dell...
Un milione di chilometri garantiti e 100...
AMD sfida Qualcomm? Nuovi indizi sul pri...
YouTube si rinnova: nuovo video player c...
Windows 11, arriva il Patch Tuesday di o...
Serve un minuto per risparmiare davvero ...
Windows 10 riceve l'ultimo Patch Tuesday...
Europa alla riscossa, Dragon LLM è...
Bluetti lancia la nuova Pioneer Na, powe...
Microsoft interrompe il supporto a Offic...
HUAWEI FreeBuds 7i: un'ottima cancellazi...
Olivetti Programma 101 compie 60 anni: q...
Settembre da primato per le auto elettri...
Mercedes Vision Iconic: l'auto con verni...
Driver Windows più affidabili: Mi...
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: 10:34.


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