'Voir le zip
Télécharger le zip
le meme generateur que windows ???Ce sont les progs qui en generent.
il parlait du Rnd de visual basic je pense !
Juste une remarque. ça ne génère pas un nombre aléatoire !et d'une les résultats sont totalement prévisible,et de deux le cycle de retour des mêmes valeurs est trop petite.Toutes les 18 valeurs générés on tombe sur la même. (seul la toute première diffère : 0,5 le premier cycle pour 0,43808 les cycles suivants) bref on a :0,43808 (ou 0,5la première fois)0,2819522565958280,5268670091586830,616281250,1225245133342080,6550706334405720,352118627691840,5676194797975420,5983135252377760,280,4629150,20756347201380,702580354223820,1787226883260190,2561953447929820,2226574883553280,43196345325570,642108547152020,438080,2819522565958280,5268670091586830,61628125...voila voila, désolé :)
ça serait pas mieux déjà avec un gettickcount ?Public Declare Function GetTickCount Lib "kernel32" Alias "GetTickCount" () As Longet tu fais :Dim rndStart as LongrndStart = GetTickCount()et pis là tu te débrouilles comme tu sais le faireça te donne au millième de seconde pres l'heure de l'ordi... donc y'a peu de chances que tu lances ton prog exactement au même moment !d'ailleurs, je me trompe peut-etre, mais il me semble que Randomize qui initie la fonction Rnd utilise l'heure de l'ordi, genre gettickcount...et comme te le fait remarquer orisa, c'est pas génial de l'aléatoire comme ça, ça fait une boucle beaucoup trop courte...utilise des long, reprend l'heure apres un délai généré aléatoirement (par ton algo)... à mon avis l'effet aléatoire sera beaucoup plus puissant...en tout cas, ça vient d'une bonne idée...allez bonne prog...Helkanen
resalut !ça y est !j'ai essayé avec un GetTickCount (même plusieurs) et j'arrive à faire qqchose d'aléatoire, malgré quelques failles de temps en temps...voilà, j'ai fait un truc de barbare, mais j'ai essayé et la moyenne varie entre 4.8 et 5.2 sur quelques lancers.et voici des résultats :0,5929193842140070,7280138715693690,4158356572530470,2545764336568510,2161323371342480,5933926281360090,8015544342554330,3800027260335850,3818211055413450,3139175761992070,3471841992756320,4475284154015710,8594529241902910,0769511456110890,5655921647542850,749687718034070,1622198162018550,5109238207251320,6789224830400970,9191287534810670,6155900024522430,396527671322220,2332535117677320,4147360720370830,7625410462369310,2509337728211250,7775062881686240,6373845286499250,1914785282631510,3714064409672360,4712849002575010,5403061351545840,5403061351545840,4078661388145370,5629148163309740,5865291298749610,4164114693922620,2327485840582290,5021562038641290,2413876049513610,7843142402210220,6921517658514630,5750535238103480,3200133318649230,4292161137003950,4499770381795240,3888541258961030,5273926313910490,4583375685879570,4490431411452280,4847435339183210,3440554109418560,5771027652176280,5696924070570470,3553976889680540,5456268061095030,7692090161339480,6904583356710250,7037100282061280,132453190178207à chaque fois que tu réessayeras, ça changera complètement.tu initialises tes valeurs de a et de b (presque) aléatoirement :b = GetTickCount Mod &H1000 + 1 'un nombre aléatoire entre 1 et 32000 (256*256)a = GetTickCount Mod &H10 + 1 'un nombre aléatoire entre 1 et 10ensuite, tu changes un peu ton code:If b <= 0 Thenb = GetTickCount Mod &H1000 + 1 'max 32000 et des poussièresElseb = b - 1End If'pas de 0 si possible, alors :If b <= 0 Then b = 5547 '5547 pris au hasardet :If a >= 17 Thena = GetTickCount Mod &HF + 1 'max 17Elsea = a + 1End If'et comme on sait jamais, on préfère ne pas avoir de 0, donc :If a <= 0 Then a = 94 '94 pris au hasard'puis :While alea1 > 100alea1 = alea1 / 10Wendalea1 = alea1 - Int(alea1)là, je prends pas directement le premier ou le deuxième chiffre parce qu'en prenant le premier chiffre, on n'aura jamais de valeur entre 0 et 0.1, et en prenant le deuxième, on trouve souvent les mêmes valeurs, le 3eme chiffre est donc le meilleur...je fais pareil avec bet pour calculer la moyenne, qui me permet de vérifier mes dires :alea = (alea1 + alea2) / 2nbLancers = nbLancers + 1Moyenne = Moyenne + (alea - Moyenne) / nbLancersvoilàpour l'optimisation, même si je ne fais pas grand chose, tu devrais penser à mettre des valeurs plus petites dans tes intervalles des Timer (genre 5,7,11), virer le Timer4 et virer les affichagesmets un log de tes valeurs si tu veuxstrLog = strLog & vbCrLf & Format(alea, "0.###############")comme ça ça va bcp plus vite ! (même si c'est toujours pas génial...)bonne prog, et adapte ça vite fait en une bonne fonction...Helkanenps: désolé je t'ai maché le travail...
voilà, j'ai fait un module...si tu veux aller le voir...http://www.vbfrance.com/code.aspx?ID=17537ps : merci pour l'idée...
Se souvenir du profil
Mot de passe oublié ? / Activation de compteCréer un compte
1 875 106 membres 8 nouveaux aujourd'hui 16 153 membres club