C++ Verständnis eines Programms



  • @Quiche-Lorraine

    Löbliches Vorhaben, aber der Ansatz des TE (oder des C++ Autors) ist schon Käse, da sollte man dann auch nicht mehr weitermachen. Für kleine Mengen mag das ja alles noch funktionieren, aber bei großen Datenmengen macht sich O(n²) schon bemerkbar, dann sollte man Algorithmen/Datenstrukturen, die das in O(n log n) erledigen benutzen.

    Edit: Das bezieht sich auf deinen ersten Beitrag

    @TE
    Das geht jetzt vermutlich über deinen Kenntnisstand hinaus, aber dein Codeschnispel soll die Anzahl der eindeutigen Zahlen in einer Menge von Zahlen bestimmen und hat mehrere Probleme:

    1. unpassende Datenstrukturen. Statt int array[] benutzt man besser std::array<int,7>, da kann man auch direkt die Anzahl der Elemente abfragen, statt die Speichergröße des Arrays durch die Größe des Datentyps zu teilen. Das hat man früher so gemacht.
    2. eine verschachtelte for-Schleife. Die äußere Schleife führt eine innere Schleife aus, und beide laufen im schlimmsten Fall über alle Elemente, d.h. die innere Operation wird n*n oft (=> O(n²)) aufgerufen. Für 7 Elemente ist das egal, aber mach das mal für 10.000 Elemente mit einer komplexen Operation, dann wird's träge. Hier gibt's eine Übersicht des Laufzeitverhaltens für verschiedene Komplexitätsklassen.
    3. explizite Schleifen statt Funktionen aus der STL. Bevor man etwas auf Containern selber programmiert sollte man mal schauen, ob es in der STL nicht schon Funktionen gibt, die das (oder was Ähnliches) machen, wie man selbst machen möchte. Vllt muss man seine Daten etwas umorganisieren, damit eine STL-Funktion so damit arbeiten kann, wie man möchte, aber da ist die STL schon unheimlich mächtig und flexibel.

    Wenn das alles nur zur Übung ist kannst du Punkt 3) ignorieren, solltest dich aber mal mit Punkt 2) befassen. Und Punkt 1) im Allgemeinen auch, nämlich möglichst Containerklassen aus der STL zu benutzen. Das führt zwangsläufig zu Iteratoren und Funktionen, die mit Iteratoren arbeiten, und wenn man das ein Mal verstanden hat ist man C++-technisch schon ein gutes Stück vorangekommen.



  • Die gezeigten Herangehensweisen haben schlimmstenfalls O(n²) und bestenfalls O(n) (linear). Dann sind die O(n)-Varianten natürlich besser.

    Mikrooptimierungstechnisch ist nur noch zu untersuchen, wie hoch der konstante Faktor bzw. die tatsächlichen Kosten sind, bzw. ab welcher Listengröße sich die O(n)-Variante lohnt bzw. amortisiert hat.

    Hö, was meint er jetzt damit?

    Na ja, seien die tatsächlichen Kosten einmal 2 mal n² und einmal 50 mal n. Dann lohnt sich zweitere Variante erst ab 25 Listenelementen: https://www.wolframalpha.com/input?i=2n^2%3D50n

    Das war jetzt eine rechnerische Überschlagung. Die genauen Kosten sind natürlich zu ermitteln.

    ... Und in der Folge muss eine Funktion/Methode dann natürlich anhand der Listengröße eine Fallunterscheidung vornehmen.



  • Ich hab mir mal das Video angesehen, und habe den Eindruck, dass es um eine Lösung in C geht, und nicht in C++.

    Von daher - abgesehen von anderen Schwächen Eurer Vorschläge (zB. Rückgabe im ursprünglichen Array, Veränderung der Reihenfolge) - scheint mir der ursprüngliche Lösungsansatz gar nicht so schlecht zu sein.



  • @Belli

     std::cout << "Anzahl der verschiedenen Zahlen: " << zahlVerschiedene << std::endl;
    

    Taucht das im Video auch auf?



  • @Data2006 sagte in C++ Verständnis eines Programms:

    #include <iostream>

    Das ist doch kein reines C.



  • Das stimmt wohl, ich schätze, das kommt vom TE? Das, iV mit cout ist aber auch das einzige, was nicht C ist ... schau Dir ruhig mal das Video an ...



  • @DocShoe sagte in C++ Verständnis eines Programms:

    @Belli

     std::cout << "Anzahl der verschiedenen Zahlen: " << zahlVerschiedene << std::endl;
    

    Taucht das im Video auch auf?

    Da wird nur die Funktion entwickelt, die hat keine Ausgabe .... das Einzige C++ - stylige in dem Video, das ich finde, ist die Variablendeklaration dort, wo man sie braucht, und nicht am Funktionsbeginn, aber das geht doch seit einiger Zeit auch in C, oder?



  • Ja, das ist C und kommt aus dem Wintersemester 2014/2015 an der FH Bielefeld, hier die komplette Playlist zur Vorlesung.



  • @Belli sagte in C++ Verständnis eines Programms:

    @DocShoe sagte in C++ Verständnis eines Programms:

    @Belli

     std::cout << "Anzahl der verschiedenen Zahlen: " << zahlVerschiedene << std::endl;
    

    Taucht das im Video auch auf?

    Da wird nur die Funktion entwickelt, die hat keine Ausgabe .... das Einzige C++ - stylige in dem Video, das ich finde, ist die Variablendeklaration dort, wo man sie braucht, und nicht am Funktionsbeginn, aber das geht doch seit einiger Zeit auch in C, oder?

    Ja, das geht auch in C, ist aber nicht Kernighan Ritchie ...

    Und ich schaue mir meist keine Videos an...



  • @DocShoe sagte in C++ Verständnis eines Programms:

    Ja, das ist C und kommt aus dem Wintersemester 2014/2015 an der FH Bielefeld, hier die komplette Playlist zur Vorlesung.

    Ergänzung: Das ist eine Vorlesung für Bauingenieure gewesen, wenn ich das richtig sehe.

    Ergänzung 2: Jörn Loviscach ist ein deutscher Mathematiker. Er ist Professor für Ingenieurmathematik und technische Informatik an der Fachhochschule Bielefeld sowie ehemaliger stellvertretender Chefredakteur der Computer-Zeitschrift c’t. https://de.wikipedia.org/wiki/Jörn_Loviscach

    Ergänzung 3: Ich studiere zwar auch in der Nähe, bin dem Professor aber noch nicht übern Weg gelaufen. Ich kenne die Bau-Ings nicht ... Mensch, Zufälle gibts.



  • @Fragender sagte in C++ Verständnis eines Programms:

    @Belli sagte in C++ Verständnis eines Programms:

    @DocShoe sagte in C++ Verständnis eines Programms:

    @Belli

     std::cout << "Anzahl der verschiedenen Zahlen: " << zahlVerschiedene << std::endl;
    

    Taucht das im Video auch auf?

    Da wird nur die Funktion entwickelt, die hat keine Ausgabe .... das Einzige C++ - stylige in dem Video, das ich finde, ist die Variablendeklaration dort, wo man sie braucht, und nicht am Funktionsbeginn, aber das geht doch seit einiger Zeit auch in C, oder?

    Ja, das geht auch in C, ist aber nicht Kernighan Ritchie ...

    Und ich schaue mir meist keine Videos an...

    Kein Problem, guck Du Dir die Videos von S. Wagenknecht an, ich gucke mir die C - Videos an ... dann tauschen wir uns aus.



  • Jetzt geht das wieder los. 🙄 Das hat doch nix mit dem Thema zu tun.



  • Liebe/r @Belli ,
    ich verfolge auch verschiedene Threads. Aber man sollte diese nicht mischen. Professionell ist man, wenn man Probleme von einander trennen kann.



  • @Fragender sagte in C++ Verständnis eines Programms:

    Jetzt geht das wieder los. 🙄 Das hat doch nix mit dem Thema zu tun.

    Sorry, dass ich aber auch immer wieder davon anfangen muss ....



  • @Fragender stimmt, das ist C++.

    LG Heiko



  • @DocShoe vielen Dank. Ja, es sollte nur eine Übung sein.

    Ich werde mal einen Schreibtischtest machen. Und dann gut sein lassen.
    Oder kann man mit VS 2019 (nicht VS Code) unter Windows 10 sich auch die Variablen während des Programms anschauen?

    LG Heiko



  • @Data2006
    Klar kann man das, dazu musst du dein Programm im Debug-Modus übersetzen und im Debugger starten, dann kannst zu jede Zeile einzeln ausführen lassen und dir anschauen, wie sich Werte Variablen ändern. Du kannst das Debugging aus dem VS mit F5 starten.



  • Hallo @Data2006 ,
    Ergänzend möchte ich noch auf Breakpoints hinweisen, falls Du noch nicht mit einem Debuger gearbeitet hast. Du kannst das Programm mittels eines gesetzten Breakpoints an (fast) jeder Stelle im Sourcecode anhalten lassen und mit [F10] schrittweise weitergehen bzw. mit [F11] in eine Funktion/Methode springen. Die meisten Variablen werden schon angezeigt, wenn Du bei einem Stopp mit dem Cursor über diese fährst.



  • @Data2006 sagte in C++ Verständnis eines Programms:

    @Fragender stimmt, das ist C++.

    LG Heiko

    Das einzige, was in Deinem Programm C++ ist, ist cout .... und das kommt in dem von Dir verlinkten Video nicht vor!
    Wäre es C++, sähe es eher einem der hier vorgestellten Beispiele ähnlich.


Anmelden zum Antworten