Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   

Die mobilen Seiten von c++.de:
http://m.c-plusplus.de
Infos hier [BETA]

  
c++.de :: VCL (C++ Builder) ::  Festplatte katalogisieren  
Gehen Sie zu Seite Zurück  1, 2, 3
  Zeige alle Beiträge auf einer Seite
Auf Beitrag antworten
Autor Nachricht
Mike Dreamer
Mitglied

Benutzerprofil
Anmeldungsdatum: 19.03.2012
Beiträge: 3
Beitrag Mike Dreamer Mitglied 00:39:44 20.03.2012   Titel:              Zitieren

Eine Verzeichnisstruktur gleicht einem binären Baum, deren Struktur verzweigt und deren Tiefe nicht vorgegeben ist.
In solchen Fällen werden immer rekursive Funktionen oder Prozeduren programmiert.
Mann muss nur den richtigen Algorithmus entwickeln, dann klappt es auch. Also nicht einfach drauf los programmieren, sondern erst mal überlegen und die richtige Vorgehensweise ausarbeiten.

Der Denkansatz ist, das man einen Baum untersucht, und von oben nach unten in die Tiefe geht. Die Bedingung ist, wenn kein Ordner mehr vorhanden ist, dann katalogisiere den Inhalt des aktuellen Ordners.

Also in der untersten Ebene anfangen und nach oben arbeiten.

Wo speicherst Du den Inhalt denn hin?
Machst Du ein Textfile, oder Speicherst Du in eine Datenbank?
Bist Du nur am Katlogisierungsproblem, oder denkst Du auch schon über eine Synchronisierung der Verzeichnisstruktur mit dem Katalog nach?

Mike


Zuletzt bearbeitet von Mike Dreamer am 00:42:33 20.03.2012, insgesamt 1-mal bearbeitet
Braunstein
Mitglied

Benutzerprofil
Anmeldungsdatum: 16.05.2002
Beiträge: 6859
Beitrag Braunstein Mitglied 09:43:02 20.03.2012   Titel:              Zitieren

Mike Dreamer schrieb:
Eine Verzeichnisstruktur gleicht einem binären Baum, deren Struktur verzweigt und deren Tiefe nicht vorgegeben ist.

Nur, dass es kein binärer Baum ist, da beliebig viele Kindknoten auftreten können.
Mike Dreamer
Mitglied

Benutzerprofil
Anmeldungsdatum: 19.03.2012
Beiträge: 3
Beitrag Mike Dreamer Mitglied 10:01:00 20.03.2012   Titel:              Zitieren

Hallo,

also eine Verzeichnisstruktur ist wie ein binärer Baum und wird demnach genau wie einer Behandelt. Klar kann es beliebig viele Kindknoten haben. Das habe ich im letzten Semester ausgiebig mit Pascal studiert.

Gerade weil es ungewiss ist, wie viele Kindknoten enthalten sein können, ist die beste Lösung durch eine rekursive Abfrage.

Wenn man das ganze mit einer iterativen Lösung macht, ist es viel Umständlicher und der Code wird demnach auch viel länger und kann unübersichtlicher werden.

Natürlich kenne ich noch nicht C und auch nicht die Macht der OOP in C++.

Mike
Braunstein
Mitglied

Benutzerprofil
Anmeldungsdatum: 16.05.2002
Beiträge: 6859
Beitrag Braunstein Mitglied 10:15:53 20.03.2012   Titel:              Zitieren

Dagegen sag ich ja gar nichts. Natürlich ist eine rekurive Betrachtung hier gegeben. Wenn wir einfach das Wort binär vor Baum streichen bin ich zufrieden.
Tim06TR
Mitglied

Benutzerprofil
Anmeldungsdatum: 14.03.2009
Beiträge: 1427
Beitrag Tim06TR Mitglied 14:38:54 20.03.2012   Titel:              Zitieren

Ich pack das ganze gleich in einen Stream (Streamart je nach Verwendung (FileStream / StringStream wenn man beim C++ Builder bleibt) ).
Ich mache es bei meinem Ablauf auf Seite 2 letzter Post iterativ, da... Ich weiß nicht, ich brauch die Rekursion einfach nicht...

Zitat:
Mann muss nur den richtigen Algorithmus entwickeln, dann klappt es auch. Also nicht einfach drauf los programmieren, sondern erst mal überlegen und die richtige Vorgehensweise ausarbeiten.

Beides läuft. Die rekursive von DerAltenburger und auch die iterative "Lösung".
Zitat:
Gerade weil es ungewiss ist, wie viele Kindknoten enthalten sein können, ist die beste Lösung durch eine rekursive Abfrage.

Könntest du das erklären? Denn habe ich theoretisch unendlich viele Kinder lande ich im Stackoverflow.
EDIT: ahm ok, ich seh grad, dass ich auf die falsche Stelle schaute, aber dennoch bleibt die Frage.
Um die Ordner aufzulisten oder die Dateien mache ich das solang, bis die Rückgabe 0 ist. (FindNext)
Zitat:
Wenn man das ganze mit einer iterativen Lösung macht, ist es viel Umständlicher und der Code wird demnach auch viel länger und kann unübersichtlicher werden.

Wenn ich sie in Code umformuliere sind beide gleich lang (Altenburger + iterative Listen Lösung). (Gleiche Formatierung). Und das Problem ist nicht derartig kompliziert als dass ich den Überblick verlöre. - (Nur eine kleine Ausführung, kann ja richtig und akzeptiert sein was du sagst, ich bin der, der sich gerne über theoretische Informatik informieren lässt)
Zitat:
Bist Du nur am Katalogisierungsproblem, oder denkst Du auch schon über eine Synchronisierung der Verzeichnisstruktur mit dem Katalog nach?

Letzteres nein. Bisher nicht, da ich das noch nicht benötigte.

_________________
"Wie ein Komponist an seinem Klavier gleitet der Programmierer über die Tasten auf der Suche nach der perfekten Komposition" ~me --- Wehe ihr lest meine alten posts ! :D


Zuletzt bearbeitet von Tim06TR am 14:49:12 20.03.2012, insgesamt 5-mal bearbeitet
c++.de :: VCL (C++ Builder) ::  Festplatte katalogisieren  
Gehen Sie zu Seite Zurück  1, 2, 3
Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info und www.c-plusplus.net enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.