Novità

x salvo e tutti

Ciao a Tutti


Codice:
Option Explicit
Sub Main
   Dim FIn,Ini,A,B,C,D,Clp,Es,Cer
   Dim R1,R2,P1,P2,P3,P4,Salvo50,Sp
   Dim DM12,DM23,DM34,DM41,Caso,Casi,Ambetto
   Dim Amba(1),Ambo1(2),Ambo2(2),Ruo(2),Ru(3)
   Dim Po1(1),Po2(2),L(7),M(4)
   Dim Ambetto1(2),Ambetto2(2),Ambetto3(2),Ambetto4(2)
   Dim Ambetto5(2),Ambetto6(2),Ambetto7(2),Ambetto8(2)
   FIn = EstrazioneFin
   Ini = CInt(InputBox("Inserisci l'estrazione che vuoi iniziare",Salvo50,10170))'10154 ESEMPIO NELL'ARTICOLO
   Clp = CInt(InputBox(" Per quanti colpi vuoi giocare?",Salvo50,13))
   Cer = CInt(InputBox(" Vuoi visualizzare i cerchi ciclometrico? SI = 1, NO un qualsiasi altro numero ",Salvo50,1))
   Ambetto = CInt(InputBox(" Vuoi giocare gli ambetti? SI = 1, NO un qualsiasi altro numero ",Salvo50,1))
   Call ScegliRange(Ini,FIn,Ini,FIn)
   Scrivi Space(13) & "LA CHIUSURA ALTERNATIVA di ANGELO GARGIULO - SCRIPT SALVO50" & Space(13),1,,4,,3,,1
   Po1(1) = 1
   Po2(2) = 1
   Sp = " "
   For Es = Ini To FIn
      Messaggio Es
      AvanzamentoElab Ini,FIn,Es
      Caso = 0
      For R1 = 1 To 10
         For P1 = 1 To 4
            For P2 = P1 + 1 To 5
               A = Estratto(Es,R1,P1)
               B = Estratto(Es,R1,P2)
               For R2 = R1 + 1 To 12
                  If R2 = 11 Then R2 = 12
                  For P3 = 1 To 4
                     For P4 = P3 + 1 To 5
                        C = Estratto(Es,R2,P3)
                        D = Estratto(Es,R2,P4)
                        If A > 0 And C > 0 Then
                           If A <> C And A <> D And B <> C And B <> D Then
                              M(1) = A : M(2) = B : M(3) = C : M(4) = D
                              Call OrdinaMatrice(M,1)
                              DM12 = Distanza(M(1),M(2)) : DM23 = Distanza(M(2),M(3))
                              DM34 = Distanza(M(3),M(4)) : DM41 = Distanza(M(4),M(1))
                              If DM12 = 18 And DM23 = 18 And DM34 = 18 And DM41 = 36 _
                                 Or DM23 = 18 And DM34 = 36 And DM41 = 18 And DM12 = 18 _
                                 Or DM34 = 18 And DM41 = 18 And DM12 = 18 And DM23 = 36 _
                                 Or DM41 = 18 And DM12 = 36 And DM23 = 18 And DM34 = 18 Then
                                 '---------------------------------
                                 If DM12 = 18 And DM23 = 18 And DM34 = 18 And DM41 = 36 Then
                                    L(1) = M(1) : L(2) = M(2) : L(3) = M(3) : L(4) = M(4)
                                 End If
                                 If DM23 = 18 And DM34 = 36 And DM41 = 18 And DM12 = 18 Then
                                    L(1) = M(4) : L(2) = M(1) : L(3) = M(2) : L(4) = M(3)
                                 End If
                                 If DM34 = 18 And DM41 = 18 And DM12 = 18 And DM23 = 36 Then
                                    L(1) = M(3) : L(2) = M(4) : L(3) = M(1) : L(4) = M(2)
                                 End If
                                 If DM41 = 18 And DM12 = 36 And DM23 = 18 And DM34 = 18 Then
                                    L(1) = M(2) : L(2) = M(3) : L(3) = M(4) : L(4) = M(1)
                                 End If
                                 L(5) = Fuori90(L(2) + 9)
                                 L(6) = Fuori90(L(3) + 9)
                                 L(7) = Fuori90(L(1) + 9)
                                 Amba(1) = L(5)
                                 Ambo1(1) = Amba(1) : Ambo1(2) = L(6)
                                 Ambo2(1) = Amba(1) : Ambo2(2) = L(7)
                                 Caso = Caso + 1
                                 Casi = Casi + 1
                                 Scrivi String(89,"*") & " Casi Totali " & FormattaStringa(Casi,"0000"),1,,,1
                                 Scrivi String(80,"*") & " Estrazione " &(Es) & " caso " & FormattaStringa(Caso,"0000"),1,,,2
                                 Scrivi
                                 ReDim MatrCasella(4,1)
                                 MatrCasella(1,0) = R1
                                 MatrCasella(1,1) = P1
                                 MatrCasella(2,0) = R1
                                 MatrCasella(2,1) = P2
                                 MatrCasella(3,0) = R2
                                 MatrCasella(3,1) = P3
                                 MatrCasella(4,0) = R2
                                 MatrCasella(4,1) = P4
                                 Call DisegnaEstrazione(Es,MatrCasella,,vbBlue)
                                 Scrivi
                                 If Cer = 1 Then
                                    DisegnaCerchioCiclometrico M,1,1,,,1,1
                                    DisegnaCerchioCiclometrico L,1,1,,,1,1
                                 End If
                                 Scrivi
                                 Scrivi Space(24) & Format2(Amba(1)) & " Ambata",1,,,2
                                 Scrivi
                                 Ruo(1) = R1 : Ruo(2) = R2
                                 Ru(1) = R1 : Ru(2) = R2 : Ru(3) = TT_
                                 ImpostaGiocata 1,Amba,Ruo,Po1,5,1
                                 ImpostaGiocata 2,Ambo1,Ru,Po2,Clp
                                 ImpostaGiocata 3,Ambo2,Ru,Po2,Clp
                                 Gioca Es,1
                                 If Ambetto = 1 Then
                                    Ambetto1(1) = Ambo1(1) : Ambetto1(2) = Fuori90(Ambo1(2) + 1)
                                    Ambetto2(1) = Ambo1(1) : Ambetto2(2) = Fuori90((90 + Ambo1(2)) - 1)
                                    Ambetto3(1) = Ambo1(2) : Ambetto3(2) = Fuori90(Ambo1(1) + 1)
                                    Ambetto4(1) = Ambo1(2) : Ambetto4(2) = Fuori90((90 + Ambo1(1)) - 1)
                                    Ambetto5(1) = Ambo2(1) : Ambetto5(2) = Fuori90(Ambo2(2) + 1)
                                    Ambetto6(1) = Ambo2(1) : Ambetto6(2) = Fuori90((90 + Ambo2(2)) - 1)
                                    Ambetto7(1) = Ambo2(2) : Ambetto7(2) = Fuori90(Ambo2(1) + 1)
                                    Ambetto8(1) = Ambo2(2) : Ambetto8(2) = Fuori90((90 + Ambo2(1)) - 1)
                                    Scrivi Space(15) & "AMBETTI",1,,,2
                                    ImpostaGiocata 4,Ambetto1,Ruo,Po2,Clp
                                    ImpostaGiocata 5,Ambetto2,Ruo,Po2,Clp
                                    ImpostaGiocata 6,Ambetto3,Ruo,Po2,Clp
                                    ImpostaGiocata 7,Ambetto4,Ruo,Po2,Clp
                                    ImpostaGiocata 8,Ambetto5,Ruo,Po2,Clp
                                    ImpostaGiocata 9,Ambetto6,Ruo,Po2,Clp
                                    ImpostaGiocata 10,Ambetto7,Ruo,Po2,Clp
                                    ImpostaGiocata 11,Ambetto8,Ruo,Po2,Clp
                                    Gioca Es,1
                                 End If
                              End If
                           End If
                        End If
                     Next
                  Next
               Next
            Next
         Next
      Next
      If ScriptInterrotto Then Exit Sub
   Next
   ScriviResoconto
   Scrivi " Tempo Trascorso" & TempoTrascorso
End Sub
 
Ciao a Tutti

Claudio8, Cutoff, Dragon8698, Matematico, Rudivall, Toon
Grazie

Su suggerimento di Claudio8 ho messo VerificaAmbetto, però questa verifica non l'ho fatta sui 2 ambi, ma sulla terna (ambata più i 2 abbinamenti)

Qualche altro suggerimento è sempre gradito.

Codice:
Option Explicit
Sub Main
   Dim FIn,Ini,A,B,C,D,Clp,Es,Cer,RetNum,X,EsClp
   Dim R1,R2,P1,P2,P3,P4,Salvo50,Sp,RetVinc
   Dim DM12,DM23,DM34,DM41,Caso,Casi,Ambetto,Ambetti
   Dim Amba(1),Ambo1(2),Ambo2(2),Ruo(2),Ru(3)
   Dim Po1(1),Po2(2),L(7),M(4),Num(3)
   FIn = EstrazioneFin
   Ini = CInt(InputBox("Inserisci l'estrazione che vuoi iniziare",Salvo50,10170))'10154 ESEMPIO NELL'ARTICOLO
   Clp = CInt(InputBox(" Per quanti colpi vuoi giocare?",Salvo50,13))
   Cer = CInt(InputBox(" Vuoi visualizzare i cerchi ciclometrico? SI = 1, NO un qualsiasi altro numero ",Salvo50,1))
   Ambetti = CInt(InputBox(" Vuoi giocare gli ambetti? SI = 1, NO un qualsiasi altro numero ",Salvo50,1))
   Call ScegliRange(Ini,FIn,Ini,FIn)
   Scrivi Space(10) & "LA CHIUSURA ALTERNATIVA di ANGELO GARGIULO - SCRIPT SALVO50" & Space(10),1,,4,,3,,1
   Po1(1) = 1
   Po2(2) = 1
   Sp = " "
   For Es = Ini To FIn
      Messaggio Es
      AvanzamentoElab Ini,FIn,Es
      Caso = 0
      For R1 = 1 To 10
         For P1 = 1 To 4
            For P2 = P1 + 1 To 5
               A = Estratto(Es,R1,P1)
               B = Estratto(Es,R1,P2)
               For R2 = R1 + 1 To 12
                  If R2 = 11 Then R2 = 12
                  For P3 = 1 To 4
                     For P4 = P3 + 1 To 5
                        C = Estratto(Es,R2,P3)
                        D = Estratto(Es,R2,P4)
                        If A > 0 And C > 0 Then
                           If A <> C And A <> D And B <> C And B <> D Then
                              M(1) = A : M(2) = B : M(3) = C : M(4) = D
                              Call OrdinaMatrice(M,1)
                              DM12 = Distanza(M(1),M(2)) : DM23 = Distanza(M(2),M(3))
                              DM34 = Distanza(M(3),M(4)) : DM41 = Distanza(M(4),M(1))
                              If DM12 = 18 And DM23 = 18 And DM34 = 18 And DM41 = 36 _
                                 Or DM23 = 18 And DM34 = 36 And DM41 = 18 And DM12 = 18 _
                                 Or DM34 = 18 And DM41 = 18 And DM12 = 18 And DM23 = 36 _
                                 Or DM41 = 18 And DM12 = 36 And DM23 = 18 And DM34 = 18 Then
                                 '---------------------------------
                                 If DM12 = 18 And DM23 = 18 And DM34 = 18 And DM41 = 36 Then
                                    L(1) = M(1) : L(2) = M(2) : L(3) = M(3) : L(4) = M(4)
                                 End If
                                 If DM23 = 18 And DM34 = 36 And DM41 = 18 And DM12 = 18 Then
                                    L(1) = M(4) : L(2) = M(1) : L(3) = M(2) : L(4) = M(3)
                                 End If
                                 If DM34 = 18 And DM41 = 18 And DM12 = 18 And DM23 = 36 Then
                                    L(1) = M(3) : L(2) = M(4) : L(3) = M(1) : L(4) = M(2)
                                 End If
                                 If DM41 = 18 And DM12 = 36 And DM23 = 18 And DM34 = 18 Then
                                    L(1) = M(2) : L(2) = M(3) : L(3) = M(4) : L(4) = M(1)
                                 End If
                                 L(5) = Fuori90(L(2) + 9)
                                 L(6) = Fuori90(L(3) + 9)
                                 L(7) = Fuori90(L(1) + 9)
                                 Amba(1) = L(5)
                                 Ambo1(1) = Amba(1) : Ambo1(2) = L(6)
                                 Ambo2(1) = Amba(1) : Ambo2(2) = L(7)
                                 Num(1) = L(5) : Num(2) = L(6) : Num(3) = L(7)
                                 Caso = Caso + 1
                                 Casi = Casi + 1
                                 Scrivi String(89,"*") & " Casi Totali " & FormattaStringa(Casi,"0000"),1,,,1
                                 Scrivi String(80,"*") & " Estrazione " &(Es) & " caso " & FormattaStringa(Caso,"0000"),1,,,2
                                 Scrivi
                                 ReDim MatrCasella(4,1)
                                 MatrCasella(1,0) = R1
                                 MatrCasella(1,1) = P1
                                 MatrCasella(2,0) = R1
                                 MatrCasella(2,1) = P2
                                 MatrCasella(3,0) = R2
                                 MatrCasella(3,1) = P3
                                 MatrCasella(4,0) = R2
                                 MatrCasella(4,1) = P4
                                 Call DisegnaEstrazione(Es,MatrCasella,,vbBlue)
                                 Scrivi
                                 If Cer = 1 Then
                                    DisegnaCerchioCiclometrico M,1,1,,,1,1
                                    DisegnaCerchioCiclometrico L,1,1,,,1,1
                                 End If
                                 Scrivi
                                 Scrivi
                                 Ruo(1) = R1 : Ruo(2) = R2
                                 Ru(1) = R1 : Ru(2) = R2 : Ru(3) = TT_
                                 ImpostaGiocata 1,Amba,Ruo,Po1,5,1
                                 ImpostaGiocata 2,Ambo1,Ru,Po2,Clp
                                 ImpostaGiocata 3,Ambo2,Ru,Po2,Clp
                                 Gioca Es,1
                                 If Ambetti = 1 Then
                                    Scrivi Space(19) & "AMBETTI",1,,,2
                                    EsClp = Es + Clp
                                    If EsClp > FIn Then EsClp = FIn
                                    For X = Es + 1 To EsClp
                                       Ambetto = VerificaAmbetto(Num,R1,X,RetNum,RetVinc)
                                       If Ambetto > 0 Then
                                          Scrivi(" Estrazione n." & Format2(X) & " del " & DataEstrazione(X)),1,0
                                          Scrivi " Ambetto su " & RetNum & Space(4) & " Vincita di " & RetVinc,1
                                          Ambetto = 0
                                       End If
                                       Ambetto = VerificaAmbetto(Num,R2,X,RetNum,RetVinc)
                                       If Ambetto > 0 Then
                                          Scrivi(" Estrazione n." & Format2(X) & " del " & DataEstrazione(X)),1,0
                                          Scrivi " Ambetto su " & RetNum & Space(4) & " Vincita di " & RetVinc,1
                                          Ambetto = 0
                                       End If
                                    Next
                                 End If
                              End If
                           End If
                        End If
                     Next
                  Next
               Next
            Next
         Next
      Next
      If ScriptInterrotto Then Exit Sub
   Next
   ScriviResoconto
   Scrivi " Tempo Trascorso" & TempoTrascorso
End Sub
 
Ultima modifica:
Ciao a Tutti

Per chi vuole lo script di pagina #6 è da riprendere, ho aggiunto negli ambetti il numero estrazione e la data di uscita
 

Ultima estrazione Lotto

  • Estrazione del lotto
    sabato 14 marzo 2026
    Bari
    34
    85
    22
    52
    09
    Cagliari
    88
    62
    57
    53
    80
    Firenze
    11
    46
    34
    49
    15
    Genova
    64
    62
    78
    30
    65
    Milano
    56
    16
    31
    12
    49
    Napoli
    44
    66
    80
    45
    07
    Palermo
    39
    38
    83
    66
    84
    Roma
    76
    52
    44
    04
    33
    Torino
    38
    08
    17
    70
    05
    Venezia
    84
    69
    42
    74
    29
    Nazionale
    89
    44
    17
    25
    52
    Estrazione Simbolotto
    Firenze
    19
    29
    21
    11
    14
Indietro
Alto