- Ad -
IMPRESSUM dotted_line KONTAKT dotted_line search dotted_line Contact dotted_line sitemap
201 PHP-Resource Mitglieder online


php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here!

Antwort
 
LinkBack Themen-Optionen Thema bewerten Ansicht
  #1 (permalink)  
Alt 27-09-2006, 00:23
3DMax
 PHP Senior
Links : Onlinestatus : 3DMax ist offline
Registriert seit: Jan 2004
Beiträge: 1.916
3DMax ist zur Zeit noch ein unbeschriebenes Blatt
Standard langeweile - zufallszahlen-contest

ja, könnte auch ins ot rein - hier ist ja nichts los

habe mal ein altes script von mir rausgekramt.

gesucht: 5 eindeutige zufallszahlen zwischen 1 und 15
bedingung: maximale performance bei z.b. 10.000 schleifendurchläufen


wer hat ein schnelleres script?
PHP-Code:
function getmicrotime(){
    list(
$usec$sec) = explode(" ",microtime());
    return ((float)
$usec + (float)$sec);
    }

// Stoppuhr anschmeißen
$time1=getmicrotime();

// CODE ========================================================================
$i=0;
while(
$i<10)
 {
  
$i++;
  
$k=0;
  while(
$k<10000)
   {
       
$k++;
       
// Zufallszahlen-Generator initialisieren
       
srand((double)microtime()*1000000);

       
// Auf gut Glück fünf Zufallszahlen generieren
    
$r0=rand(1,15);
    
$r1=rand(1,15);
    
$r2=rand(1,15);
    
$r3=rand(1,15);
    
$r4=rand(1,15);
    
    
// Nach dieser While-Schleife sind die ersten drei Zufallszahlen eindeutig
    
while($r0==$r1||$r1==$r2||$r0==$r2)
     {
      
$r0=rand(1,15);
      
$r1=rand(1,15);
      
$r2=rand(1,15);
     }
     
    
// Nach dieser While-Schleife sind die ersten vier Zufallszahlen eindeutig
    
while($r0==$r3||$r1==$r3||$r2==$r3)
     {
      
$r3=rand(1,15);
     }

    
// Nach dieser While-Schleife sind alle Zufallszahlen eindeutig
    
while($r0==$r4||$r1==$r4||$r2==$r4||$r3==$r4)
     {
      
$r4=rand(1,15);
     }
   }
  
// Mal testweise den ganzen Müll ausgeben (10.000 Durchläufe)
  
echo "$r0, $r1, $r2, $r3, $r4 <br>";
 }
// =============================================================================

// Stoppuhr stoppen (wie schon der Name sagt) 
$time2=getmicrotime();

// Die fantastische Laufzeit des genialen Algorithmus ausgeben
echo "<br>RUNTIME: ";
echo 
$time2-$time1
Mit Zitat antworten
  #2 (permalink)  
Alt 27-09-2006, 00:50
axo
 Junior Member
Links : Onlinestatus : axo ist offline
Registriert seit: Jan 2006
Ort: 127.0.0.1
Beiträge: 196
axo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

ohje

PHP-Code:
$vals array_rand(range(0,14,1), 5); 
... um meine ausgabe mit deiner identisch zu gestalten, müsste man die zufallswerte zum schluss noch um eins inkrementieren. array_rand gibt die _schlüssel_ des arrays zurück, und nicht die werte selbst - wenn ich mit 0 zu zählen anfange, sind schlüssel und werte in diesem fall identisch und man spart sich einen durchlauf.

srand ist im übrigen seit 4.2.0 obsolet.

Geändert von axo (27-09-2006 um 00:56 Uhr)
Mit Zitat antworten
  #3 (permalink)  
Alt 27-09-2006, 01:20
Slava
 PHP Senior
Links : Onlinestatus : Slava ist offline
Registriert seit: Nov 2002
Ort: Köln
Beiträge: 1.583
Slava befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Original geschrieben von axo
ohje

PHP-Code:
$vals array_rand(range(0,14,1), 5); 
... um meine ausgabe mit deiner identisch zu gestalten, müsste man die zufallswerte zum schluss noch um eins inkrementieren.
neee
man macht einfach range(1,15)
in jedem fall ist deine Version einwenig kürzer als bei 3DMax.
getestet habe ich es nicht, aber ich glaube, dass es auch schneller ist.
__________________
Slava
bituniverse.com
Mit Zitat antworten
  #4 (permalink)  
Alt 27-09-2006, 01:32
3DMax
 PHP Senior
Links : Onlinestatus : 3DMax ist offline
Registriert seit: Jan 2004
Beiträge: 1.916
3DMax ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Original geschrieben von axo

srand ist im übrigen seit 4.2.0 obsolet.
wie gesat, das script ist älter.
array_rand ist mehr als doppelt so schnell!
Mit Zitat antworten
  #5 (permalink)  
Alt 27-09-2006, 08:43
axo
 Junior Member
Links : Onlinestatus : axo ist offline
Registriert seit: Jan 2006
Ort: 127.0.0.1
Beiträge: 196
axo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Original geschrieben von Slava
neee
man macht einfach range(1,15)
nein: http://de3.php.net/array_rand
Zitat:
If you are picking only one entry, array_rand() returns the key for a random entry. Otherwise, it returns an array of keys for the random entries.
führt in unserem fall dazu, dass auch bei range(1,15) die 0 als wert zugelassen wird.
Mit Zitat antworten
  #6 (permalink)  
Alt 27-09-2006, 09:26
axo
 Junior Member
Links : Onlinestatus : axo ist offline
Registriert seit: Jan 2006
Ort: 127.0.0.1
Beiträge: 196
axo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

wobei:

PHP-Code:
$bla range(0,15);
unset(
$bla[0]);
$vals array_rand($bla5); 
... jetzt passts. alle werte von 1 bis 15 ...
Mit Zitat antworten
  #7 (permalink)  
Alt 27-09-2006, 11:13
Slava
 PHP Senior
Links : Onlinestatus : Slava ist offline
Registriert seit: Nov 2002
Ort: Köln
Beiträge: 1.583
Slava befindet sich auf einem aufstrebenden Ast
Standard

ich bin davon ausgagengen, dass man sowieso ausgabe mit echo machen muss.
PHP-Code:
$a=range(1,15);
$v=array_rand($a5);
//kann man auch ohne schleife $a[$v[0]] ...
foreach($v as $v){echo $a[$v].",";} 
__________________
Slava
bituniverse.com
Mit Zitat antworten
  #8 (permalink)  
Alt 27-09-2006, 11:30
Trashar
 PHP Senior
Links : Onlinestatus : Trashar ist offline
Registriert seit: Dec 2001
Ort: /root/
Beiträge: 1.366
Trashar ist zur Zeit noch ein unbeschriebenes Blatt
Trashar eine Nachricht über ICQ schicken Trashar eine Nachricht über AIM schicken
Standard

foreach($v as $v) ???!
na was geht daran nicht?
Mit Zitat antworten
  #9 (permalink)  
Alt 27-09-2006, 12:41
combie
 PHP Expert
Links : Onlinestatus : combie ist offline
Registriert seit: May 2006
Beiträge: 2.342
combie befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Original geschrieben von Trashar
foreach($v as $v) ???!
na was geht daran nicht?
Das würde ich auch mal gerne wissen.....
(Dir ist aber schon klar, daß foreach eine interne Kopie des Arrays anlegt, oder?)
Mit Zitat antworten
  #10 (permalink)  
Alt 27-09-2006, 12:49
Slava
 PHP Senior
Links : Onlinestatus : Slava ist offline
Registriert seit: Nov 2002
Ort: Köln
Beiträge: 1.583
Slava befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Original geschrieben von Trashar
foreach($v as $v) ???!
na was geht daran nicht?
was soll da nicht gehen?
__________________
Slava
bituniverse.com
Mit Zitat antworten
  #11 (permalink)  
Alt 27-09-2006, 13:59
Trashar
 PHP Senior
Links : Onlinestatus : Trashar ist offline
Registriert seit: Dec 2001
Ort: /root/
Beiträge: 1.366
Trashar ist zur Zeit noch ein unbeschriebenes Blatt
Trashar eine Nachricht über ICQ schicken Trashar eine Nachricht über AIM schicken
Standard

überschreiben die sich nicht?!
ich habs nicht ausprobiert nur mal so von der logik her..
Mit Zitat antworten
  #12 (permalink)  
Alt 27-09-2006, 14:01
combie
 PHP Expert
Links : Onlinestatus : combie ist offline
Registriert seit: May 2006
Beiträge: 2.342
combie befindet sich auf einem aufstrebenden Ast
Standard

Nein!
Das tuts so!

Nach Ablauf der Schleife, ist in $v natürlich nur das letzte Arrayelement.
Mit Zitat antworten
  #13 (permalink)  
Alt 28-09-2006, 02:14
Breezzer
 Registrierter Benutzer
Links : Onlinestatus : Breezzer ist offline
Registriert seit: Nov 2005
Beiträge: 85
Breezzer ist zur Zeit noch ein unbeschriebenes Blatt
Standard

nur mal so ne frage:

wie zum teufel kommt man auf die idee, ein script wie im ersten post zu schreiben?^^
Mit Zitat antworten
  #14 (permalink)  
Alt 28-09-2006, 02:17
combie
 PHP Expert
Links : Onlinestatus : combie ist offline
Registriert seit: May 2006
Beiträge: 2.342
combie befindet sich auf einem aufstrebenden Ast
Standard

Langeweile.?.. !

Übrigens, es besteht die (zugegebenermaßen geringe) Gefahr, daß das Script aus dem ersten Posting nie endet.

Meines Erachtens nach, könnte ein Zufallsgenerator wochenlang nur 3en liefern..
was passiert dann in den while Schleifen, da oben...

Geändert von combie (28-09-2006 um 02:58 Uhr)
Mit Zitat antworten
Antwort

Lesezeichen


Themen-Optionen
Ansicht Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

Kritische Sicherheitlücke in vBulletin verrät MySQL-Login
Kritische Sicherheitlücke in vBulletin verrät MySQL-LoginDie beliebte Forensoftware vBulletin verrät mit minimalem Aufwand die Zugangsdaten zum MySQL-Server!

26.07.2010 | Berni

Sencha Touch HTML5-Framework für iOS und Android
Sencha Touch HTML5-Framework für iOS und AndroidMit dem Framework Sencha Touch lassen sich schnell Webapplikationen für mobile Endgeräte entwickeln.

17.06.2010 | Berni

 

Neuzugänge PHP Scripte

Komplettes SMS Script

Wir bieten Ihnen hier ein Komplettes SMS Portal-Script (Nutzlizenz) mit tollen Verdienstmoeglichkeiten. Vergleichbare Scripte kosten normalerweise mehrere hundert Euro !!

29.07.2010 ISD-Genthin | Kategorie: PHP/ sonstig
PHP Gästebuch Script

Es gibt hier eine kostenloses PHP Gästebuch Script.

29.07.2010 Nico_Schubert | Kategorie: PHP/ Gaestebuch
Autoresponder Script ansehen Autoresponder Script

The Autoresponder Script is an easy to use CGI/Perl script.

29.07.2010 esoft24 | Kategorie: PERL/ Mail
phplinX-Anzeigenmarkt Professional V2.1 ansehen phplinX-Anzeigenmarkt Professional V2.1

Mit unsererem PHP-Script phplinX Anzeigenmarkt Professional V2.1 erwerben Sie ein komplettes Kleinanzeigen-System inklusive einer bedienerfreundlichen Administration mit zahlreichen wichtigen Funktionen.

28.07.2010 Cosinus14 | Kategorie: PHP/ Anzeigenmarkt
DynDNS-Update-Script

Dieses Script bildet einen DynDNS-Server, nimmt also die DynDNS-Client-Mitteilungen an und speichert diese ab. Bei einem normalen Aufruf leitet es automatisch an die jeweilige aktuelle IP-Adresse des Client-PCs weiter.

27.07.2010 Fireball22 | Kategorie: PHP/ Network
Fakemailer-Script

Der Fakemailer ermöglicht das Versenden von E-Mails von beliebigen Absender-E-Mail-Adressen an beliebige Empfänger-E-Mail-Adressen.

27.07.2010 Fireball22 | Kategorie: PHP/ Mail
 Alle Scipte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 23:51 Uhr.

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