Algorithmen Analyse einer Schleife

JavaUndC-Prog

Bekanntes Mitglied
Guten Tag,

ich bin im Netz auf interessante Folien zum Thema Analyse von Algorithmen gestoßen. Dort wird beispielsweise ein einfacher Programmcode analysiert. Das ist diese typische Frage nach, wie oft wird Operation XY ausgeführt bzw. was sind die Kosten des Algos. Jetzt habe ich selber einmal meine Analyse gestartet und stimme nicht mit dem überein, was dort gesagt wird. In großen Teilen und unter gewissen Annahmen kann ich manchem jedoch zustimmen. Ich halte das mal relativ einfach um was es hier im Kern geht.

Angenommen es gibt eine typische Schleife, wie diese hier:
Java:
for(int i = 1; i < n; i++){
    // Anweisung
}

Jetzt ist die Frage nach der Anzahl der Ausführungen. Das demonstriere ich mal anhand einiger Szenarien:
Fall n = 0:
int i = 1 // wird 1x ausgeführt
i < n // wird 1x ausgeführt, danach Exit...

Fall n = 1:
int i = 1 // wird 1x ausgeführt
1 < n // wird 1x ausgeführt, danach Exit

Fall n = 2:
int i = 1 // wird 1x ausgeführt
i < n // wird 1x ausgeführt
Anweisung kommt
i++ // wird 1x ausgeführt
1 < n // wird 1x ausgeführt, danach Exit

Jetzt wird für die Schleife folgendes behauptet:
  • int i = 1 wird einmal ausgeführt // kann ich bestätigen
  • i < n // wird n mal ausgeführt // kann ich nicht bestätigen (siehe Fall n = 0), würde man die n = 0 als Fall streichen, stimmt das!
  • i++ wird n-1 mal ausgeführt // fast, würde stimmen, wenn der Fall n = 0 nicht beachtet werden würde
Das bringt mich zu folgendem allgemeinen Schluss, würde man die 0 als Fall auslassen, könnte man allgemein für die Schleife behaupten, dass in Summe: 1 (für int i = 1) + n + (n-1) Operationen ausgeführt werden. Bei der Analyse von Algorithmen würde man in diesem Beispiel den Fall 0 einfach wegfallen lassen, oder würde der als Sonderfall gehandhabt werden? Was meint ihr?
 

mihe7

Top Contributor
Fall 0 und 1 sind identisch: die Schleife terminiert ohne Iteration. Bis dahin sind zwei Schritte nötig, nämlich die Initialisierung und der Vergleich. Jeder Iteration folgen zwei Operationen, nämlich ein Inkrement und ein Vergleich. Die Zahl der Iterationen m ist abhängig vom Startwert s und dem Inkrement. Wird jeweils 1 addiert, ergibt sich m = max{0, m-s}, und damit insgesamt 2*(m+1) Schritte.
 

JavaUndC-Prog

Bekanntes Mitglied
Dann würde mich mal interessieren, wie du das allgemein notieren würdest, wenn es um die Anzahl der Schritte geht, ich mach mal vor was ich meine:
Java:
        for(int i = 1; i < n; i++) {    // N + 1 Schritte da:
            // i = 1 ist 1 Schritt,
            // i < n sind N + 1 Schritte,
            // i++ sind N Schritte 
            // --> max sind N+1
            if(j == k) {                //  1 Schritt aber N Schritte in der Schleife
                // Anweisung 1            // 1 Schritt
            }
            // Anweisung 2                // N Schritte       
        }                                // 1 + 1 + (N+1) + N + 1 + N

Mich würde das gleiche Beispiel für i = 1 mit i <=n, sowie i = 0 mit i < n oder i <=n interessieren :)
Es scheint hier überall andere Notationen zu geben, das verwirrt mich etwas...
 

mihe7

Top Contributor
Wenn Du es als while-Schleife formulierst, wird es deutlicher:
Java:
int i = 1; // 1 Schritt
while (i < n) { // Vergleich wird n-mal wiederholt, da zu Beginn i == 1 gilt
    if (j == k) {  // Vergleich wird (n-1)-mal wiederholt
        // wie oft die Anweisungen ausgeführt werden, hängt von der Bedingung j == k ab
    }
    i++; // wird (n-1)-mal wiederholt
}

Es scheint hier überall andere Notationen zu geben, das verwirrt mich etwas...
Das hatten wir erst in einem anderen Thread. Der Punkt ist, dass die exakte Schrittzahl in der Regel nicht interessiert, weil am Ende die Zeitkomplexität bestimmt wird und "ein Schritt" sowieso nur eine Abstraktion ist. Ob Du zur Bestimmung der Komplexität nun die Initialisierung dazuzählst oder nicht, spielt keine Rolle.

Nachtrag:
Mich würde das gleiche Beispiel für i = 1 mit i <=n, sowie i = 0 mit i < n oder i <=n interessieren :)
Hier erhöht sich einfach die Anzahl um 1, falls i mit 0 oder auf i<=n geprüft wird, bzw. um 2, falls i mit 0 initialisiert und i<=n geprüft wird.
 

JavaUndC-Prog

Bekanntes Mitglied
Hey, danke für deine Antwort!

Ich würde deinen Ausführungen soweit auch Zustimmen, da habe ich keinen Einwand! "Hier erhöht sich einfach die Anzahl um 1, falls i mit 0 oder auf i<=n geprüft wird, bzw. um 2, falls i mit 0 initialisiert und i<=n geprüft wird. " Sehe ich auch so!

Wie gezählt wird scheint tatsächlich sehr zu variieren... In deiner While Schleife z.B. sagst du ja auch aus, dass du n-mal wiederholst und innerhalb der Schleife die Anweisungen n-1 Mal wiederholt werden. Ich habe mir angewöhnt zu merken, dass der Schleifen Kopf einmal mehr gezählt wird, als die Anweisungen in der Schleife selbst. Auch zähle ich den Schleifen Kopf mit n+1 wohingegen ich das in der Schleife mit n zähle. Wahrscheinlich mündet das darin, dass man je nach Zählart am Ende eben bsp. 7n+3 oder 3n + 5 zählt, hierbei interessiert dann aber eigentlich nur dass es in O(n) liegt. Trotzdem wäre es sehr schön, wenn das vereinheitlicht würde... :)
 

mihe7

Top Contributor
Trotzdem wäre es sehr schön, wenn das vereinheitlicht würde... :)
Je nach Sichtweise ist das schwierig bzw. bereits vereinheitlicht.

Beispielsweise haben wir i++ als einen Schritt gezählt, es wären aber eher zwei, nämlich eine Addition und eine Zuweisung.

Der "Schritt" ist also bereits eine Abstraktion und die Frage ist, wovon man abstrahiert. In der Theorie ist das einfach, da arbeitet man mit klar definierten, einfachen und idealisierten Modellen. Für Hochsprachen gilt das nicht und so wird aus einem i++ ein Schritt, obwohl es zwei wären.

Die Frage ist jetzt, ob bzw. warum man an der Stelle schon aufhören soll, zu abstrahieren. Letztlich können wir für "i++" einen Schritt zählen, weil die Zeit konstant ist. Ein i++ hat also die gleiche Komplexität wie ein i = 1. Wir können also die Initialisierung auch noch dazu nehmen, dann haben wir für Initialisierung und i++ einen Schritt und schon ändert sich die ganze Zählerei.

Vereinheitlicht ist diese insofern, als man Komplexität "zählt", zum Beispiel so:
Code:
int i = 1; // O(1)
while (i < n) { // O(n)
    if (j == k) {  // O(1)
        // wie oft die Anweisungen ausgeführt werden, hängt von der Bedingung j == k ab
    }
    i++; // O(1)
}
Macht insgesamt: O(n) - ganz egal, ob i nun 1 oder 0 oder -50 war.

Noch deutlicher wird es, wenn es um Algorithmen geht, die externe Daten verarbeiten. Da spielen dann (fast immer) nur noch solche Schritte eine Rolle, die auf den externen Datenträger zugreifen. Würde man die CPU-Schritte dazunehmen, ergäbe sich ein ggf. völlig falsches Bild.
 

LimDul

Top Contributor
Hinzu kommt, man zählt hier Äpfelbäume, aber verarbeitet werden hinterher Äpfel. Zwar entspricht ein Apfelbaum im großen und ganzen immer ungefähr einer gleichen Zahl Äpfel, aber nie exakt. Ob ich etwas nun als ein oder zwei Bäume zähle ist am Ende egal.

In dem Beispiel hier werden Anweisungen im Java Code gezählt. Bevor die ausgeführt werden, passiert noch:
* Umwandlung in Byte-Code (ggf. mit Optimierungen)
* Beim Ausführen umwandeln in Maschinencode mit on the fly Optimierungen je nach Virtueller Maschine und Konfiguration dieser
* Der Prozessor wiederum optimiert mit seine Pipelines da auch noch mal rum.

Sprich, ob man jetzt für gewisse Dinge 1 oder 2 Schritte zählt - am Ende kann man nicht seriös beantworten ob und was das wirklich für Auswirkungen auf die echte Laufzeit hat. Damit ist die Diskussion hier rein akademisch und eine Vereinheitlichung bringt halt nix (genauso wenig wie es sinnvoll ist allgemeingültig festzulegen, ein Apfelbaum hat 97 Äpfel). Man sollte es für die Dinge die man selber betrachtet immer gleich betrachten, um eine Vergleichbarkeit herzustellen - aber eine Vergleichbarkeit darüber hinaus ist halt eben nicht sinnvoll.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Web Crawler Algorithmen mit Jsoup Allgemeine Java-Themen 3
A Algorithmen Allgemeine Java-Themen 2
A Algorithmen Allgemeine Java-Themen 2
Gaudimagspam Algorithmen formulieren Allgemeine Java-Themen 1
D Algorithmen und Datenstrukturen in Java Allgemeine Java-Themen 40
S Algorithmen und Datenstrukturen Allgemeine Java-Themen 1
S Buch oder Website mit genialen Algorithmen..? Allgemeine Java-Themen 1
M Algorithmen und Datenstrukturen Allgemeine Java-Themen 6
C Rechenzeit verschiedener Algorithmen vergleichen Allgemeine Java-Themen 4
F deduktive algorithmen Allgemeine Java-Themen 0
X Suche Softwareimplementierung von Cryptographischen Algorithmen Allgemeine Java-Themen 3
M Aufgabenstellung unklar (Vorlesung Algorithmen und Datenstrukturen..) Allgemeine Java-Themen 2
K Frage zu ProgressBars, Algorithmen und Multithreading ->F Allgemeine Java-Themen 2
M Java Analyse/ SWOT-Analyse Allgemeine Java-Themen 13
L Fragen für Facharbeit: Analyse von Strings in Java Allgemeine Java-Themen 4
L Java Prozess 100% -> Analyse Allgemeine Java-Themen 2
P Analyse und Kategorisierung großer Datensätze Allgemeine Java-Themen 3
S SWOT-Analyse von Java Allgemeine Java-Themen 2
K Symantik-Analyse mit Java? Allgemeine Java-Themen 4
H JVM HeapDump und Analyse Allgemeine Java-Themen 2
L Analyse Tools Allgemeine Java-Themen 2
N Java-Programm zur Analyse Allgemeine Java-Themen 13
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben