1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| Public Function SIGMICNew(Plage As Range)
Dim Pas As Double
Dim Tablo
Dim Verif As Double
Dim MonDico As Object
Dim j As Integer
Set MonDico = CreateObject("Scripting.Dictionary")
Tablo = Plage
For j = LBound(Tablo, 1) To UBound(Tablo, 1)
If Tablo(j, 2) > 0 _
And Tablo(j, 2) <> "" _
And Tablo(j, 1) <> "" Then
Pas = Tablo(j, 1) / (Tablo(j, 2) * 0.8)
Verif = 0
If Pas > 0 Then
While Verif <= Tablo(j, 1)
On Error Resume Next
MonDico.Add (Tablo(j, 1) - Verif), (Tablo(j, 1) - Verif)
On Error GoTo 0
Verif = Verif + Pas
Wend
ElseIf Pas = 0 Then
On Error Resume Next
MonDico.Add (0), (0)
On Error GoTo 0
End If
End If
Next j
ReDim Tablo(MonDico.Count - 1)
Tablo = MonDico.items
Call Tri(Tablo, LBound(Tablo), UBound(Tablo))
Pas = Round((UBound(Tablo) + 1) / 5)
SIGMICNew = Tablo(UBound(Tablo) - Pas)
End Function
Sub Tri(a, gauc, droi)
'*** Codé proposé par Jacques BOISGONTIER ***
ref = a((gauc + droi) \ 2)
g = gauc: d = droi
Do
Do While a(g) < ref: g = g + 1: Loop
Do While ref < a(d): d = d - 1: Loop
If g <= d Then
temp = a(g): a(g) = a(d): a(d) = temp
g = g + 1: d = d - 1
End If
Loop While g <= d
If g < droi Then Call Tri(a, g, droi)
If gauc < d Then Call Tri(a, gauc, d)
End Sub |
Partager