mafulechka
mafulechka2. August 2019 04:28

Dynamische Programmierung

Dynamische Programmierung ist eine Computerprogrammiertechnik, die dabei hilft, eine Klasse von Problemen mit überlappenden Teilproblemen und optimalen Teilstruktureigenschaften effizient zu lösen.

Solche Probleme umfassen das wiederholte Berechnen des Werts derselben Teilprobleme, um die optimale Lösung zu finden.


Dynamisches Programmierbeispiel

Nehmen wir den Fall der Generierung der Fibonacci-Folge .

Wenn die Folge F(1) F(2) F(3) ........ F(50) ist, dann folgt die Regel F(n) = F(n-1) + F(n-2). )
F(50) = F(49) + F(48)
F(49) = F(48) + F(47)
F(48) = F(47) + F(46)
...

Beachten Sie, dass es hier überlappende Teilprobleme gibt, da wir F(48) berechnen müssen, um sowohl F(50) als auch F(49) zu berechnen. Dies ist genau der Algorithmus, bei dem ein Beispiel für dynamische Programmierung deutlich sichtbar ist.

Wie die dynamische Programmierung funktioniert

Dynamische Programmierung funktioniert, indem die Ergebnisse von Teilproblemen gespeichert werden, sodass sie zur Hand sind, wenn ihre Lösungen benötigt werden, und wir sie nicht neu berechnen müssen.

Diese Technik, den Wert von Teilaufgaben zu speichern, wird Memoisierung (Erinnern) genannt. Indem wir die Werte in einem Array speichern, sparen wir Zeit für die Berechnung von Teilproblemen, auf die wir bereits gestoßen sind.

var m = map(0 → 0, 1 → 1)
function fib(n)
    if key n is not in map m 
           m[n] = fib(n − 1) + fib(n − 2)
    return m[n]

Dynamic Programming by Memoization ist ein Top-Down-Ansatz zur dynamischen Programmierung. Indem wir die Arbeitsrichtung des Algorithmus umkehren, d. h. vom Basisfall ausgehen und auf die Lösung hinarbeiten, können wir auch Bottom-Up Dynamic Programming verwenden.

function fib(n)
       if n = 0
           return 0
       else
           var prevFib = 0, currFib = 1
           repeat n − 1 times
               var newFib = prevFib + currFib
               prevFib = currFib
               currFib  = newFib
       return currentFib

Rekursion vs. dynamische Programmierung

Dynamische Programmierung wird hauptsächlich auf rekursive Algorithmen angewendet. Dies ist kein Zufall, die meisten Optimierungsprobleme erfordern Rekursion, und zur Optimierung wird dynamische Programmierung verwendet.

Aber nicht alle Aufgaben, die Rekursion verwenden, können die dynamische Programmierung verwenden. Wenn es keine überlappenden Teilprobleme gibt, wie im Fall der Fibonacci-Folge, kann die Rekursion nur mit einem Teile-und-Herrsche-Ansatz zu einer Lösung führen.

Aus diesem Grund kann ein rekursiver Algorithmus wie "Merge Sort" keine dynamische Programmierung verwenden, da sich die Teilaufgaben in keiner Weise überschneiden.

Gierige vs. dynamische Programmierung

Gierige Algorithmen ähneln der dynamischen Programmierung insofern, als sie beide Optimierungswerkzeuge sind.

Ein gieriger Algorithmus sucht jedoch nach einer lokal optimalen Lösung, oder mit anderen Worten, einer "gierigen" Wahl in der Hoffnung, ein globales Optimum zu finden. Daher können gierige Algorithmen eine Vermutung anstellen, die optimal aussieht, aber gleichzeitig teuer wird und das Finden eines globalen Optimums nicht garantiert.

Die dynamische Programmierung hingegen findet die optimale Lösung für Teilprobleme und trifft dann eine fundierte Wahl, indem sie die Ergebnisse dieser Teilprobleme kombiniert, um die optimalste Lösung zu finden.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken