<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=AC-3-Algorithmus</id>
	<title>AC-3-Algorithmus - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=AC-3-Algorithmus"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=AC-3-Algorithmus&amp;action=history"/>
	<updated>2026-05-26T21:19:36Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=AC-3-Algorithmus&amp;diff=2682374&amp;oldid=prev</id>
		<title>imported&gt;Wiegels: Typografie</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=AC-3-Algorithmus&amp;diff=2682374&amp;oldid=prev"/>
		<updated>2022-08-24T20:04:23Z</updated>

		<summary type="html">&lt;p&gt;Typografie&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Der &amp;#039;&amp;#039;&amp;#039;AC-3-Algorithmus&amp;#039;&amp;#039;&amp;#039; (von {{enS|&amp;#039;&amp;#039;arc consistency algorithm&amp;#039;&amp;#039;}}, dt.: Kantenkonsistenz-Algorithmus) ist ein [[Algorithmus]] zur Lösung von [[Constraint-Satisfaction-Problem|Constraint-Erfüllungsproblemen]] (CSPs) mit binären Bedingungen. Er wurde 1977 von [[Alan Mackworth]] entwickelt&amp;lt;ref&amp;gt;Alan K. Mackworth: &amp;#039;&amp;#039;Consistency in Networks of Relations.&amp;#039;&amp;#039; In: &amp;#039;&amp;#039;Artificial Intelligence.&amp;#039;&amp;#039; Bd. 8, Nr. 1, Februar 1977, {{ISSN|0004-3702}}, S. 99–118, {{doi|10.1016/0004-3702(77)90007-8}}.&amp;lt;/ref&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Der Algorithmus ==&lt;br /&gt;
&lt;br /&gt;
AC-3 arbeitet auf den Domänen von Variablen in Constraint-Erfüllungsproblemen. Eine &amp;#039;&amp;#039;Variable&amp;#039;&amp;#039; kann hier jeden Wert einer festgelegten Menge, ihrer &amp;#039;&amp;#039;Domäne&amp;#039;&amp;#039;, annehmen. Diese Belegungen der Variablen werden durch klar definierte Regeln (&amp;#039;&amp;#039;Constraints&amp;#039;&amp;#039;) eingeschränkt. Diese Constraints können die Belegungen anderer Variablen beinhalten.&lt;br /&gt;
&lt;br /&gt;
Ein CSP kann als gerichteter Graph betrachtet werden, wobei die Knoten den Variablen des Problems entsprechen und die Kanten für Constraints stehen. AC-3 untersucht die Kanten zwischen Variablen-Paaren (&amp;#039;&amp;#039;x&amp;#039;&amp;#039;, &amp;#039;&amp;#039;y&amp;#039;&amp;#039;). Es werden jene Werte aus den Domänen von &amp;#039;&amp;#039;x&amp;#039;&amp;#039; und &amp;#039;&amp;#039;y&amp;#039;&amp;#039; entfernt, die nicht mit den Constraints zwischen &amp;#039;&amp;#039;x&amp;#039;&amp;#039; und &amp;#039;&amp;#039;y&amp;#039;&amp;#039; konsistent sind. Der Algorithmus speichert die Kanten, die noch geprüft werden müssen. Wenn Werte aus der Domäne einer Variable entfernt werden, werden alle Kanten (Constraints) an dieser Variable der Menge der noch zu prüfenden Kanten hinzugefügt. Da die Domänen von Variablen endlich sind – und in jedem Schritt entweder eine Kante oder eine Variable entfernt werden – terminiert der Algorithmus garantiert.&lt;br /&gt;
&lt;br /&gt;
Ein Beispiel anhand eines einfachen Problems:&lt;br /&gt;
Es sei eine Variable &amp;#039;&amp;#039;X&amp;#039;&amp;#039; mit der Domäne D(&amp;#039;&amp;#039;X&amp;#039;&amp;#039;) = {0, 1, 2, 3, 4, 5} gegeben. Außerdem sei eine Variable &amp;#039;&amp;#039;Y&amp;#039;&amp;#039; mit D(&amp;#039;&amp;#039;Y&amp;#039;&amp;#039;) = {0, 1, 2, 3, 4, 5} gegeben. Die Constraints seien &amp;#039;&amp;#039;C1&amp;#039;&amp;#039; = „&amp;#039;&amp;#039;X&amp;#039;&amp;#039; sei gerade“ und &amp;#039;&amp;#039;C2&amp;#039;&amp;#039; = „&amp;#039;&amp;#039;X&amp;#039;&amp;#039; + &amp;#039;&amp;#039;Y&amp;#039;&amp;#039; = 4“. Da AC-3 in einem gerichteten Graphen repräsentiert wird, existieren dabei aufgrund von &amp;#039;&amp;#039;C2&amp;#039;&amp;#039; zwei Kanten zwischen &amp;#039;&amp;#039;X&amp;#039;&amp;#039; und &amp;#039;&amp;#039;Y&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
Bei Anwendung von AC-3 werden zunächst die ungeraden Werte der Domäne von &amp;#039;&amp;#039;X&amp;#039;&amp;#039; entfernt, wodurch alle verbleibenden Belegungsmöglichkeiten für &amp;#039;&amp;#039;X&amp;#039;&amp;#039; (D(&amp;#039;&amp;#039;X&amp;#039;&amp;#039;) = { 0, 2, 4 }) den Constraint &amp;#039;&amp;#039;C1&amp;#039;&amp;#039; erfüllen. Anschließend werden die Kanten zwischen &amp;#039;&amp;#039;X&amp;#039;&amp;#039; und &amp;#039;&amp;#039;Y&amp;#039;&amp;#039; untersucht. Constraint &amp;#039;&amp;#039;C2&amp;#039;&amp;#039; wird nur durch die Belegungen (&amp;#039;&amp;#039;X&amp;#039;&amp;#039;=0, &amp;#039;&amp;#039;Y&amp;#039;&amp;#039;=4), (&amp;#039;&amp;#039;X&amp;#039;&amp;#039;=2, &amp;#039;&amp;#039;Y&amp;#039;&amp;#039;=2), und (&amp;#039;&amp;#039;X&amp;#039;&amp;#039;=4, &amp;#039;&amp;#039;Y&amp;#039;&amp;#039;=0) erfüllt. AC-3 terminiert mit D(&amp;#039;&amp;#039;X&amp;#039;&amp;#039;) = {0, 2, 4} und D(&amp;#039;&amp;#039;Y&amp;#039;&amp;#039;) = {0, 2, 4}.&lt;br /&gt;
&lt;br /&gt;
AC-3 in Pseudocode:&lt;br /&gt;
&lt;br /&gt;
 &amp;#039;&amp;#039;&amp;#039;function AC3&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
  &amp;#039;&amp;#039;// Reduziert Domänen&amp;#039;&amp;#039;&lt;br /&gt;
      &amp;#039;&amp;#039;&amp;#039;queue&amp;#039;&amp;#039;&amp;#039; = Alle Kanten des CSP&lt;br /&gt;
      &amp;#039;&amp;#039;&amp;#039;while&amp;#039;&amp;#039;&amp;#039; (!empty(queue))&lt;br /&gt;
          &amp;#039;&amp;#039;&amp;#039;Entferne&amp;#039;&amp;#039;&amp;#039; eine Kante (x, y) aus &amp;#039;&amp;#039;&amp;#039;queue&amp;#039;&amp;#039;&amp;#039;;&lt;br /&gt;
          &amp;#039;&amp;#039;&amp;#039;if&amp;#039;&amp;#039;&amp;#039;(EntferneInkonsistenteWerte(x, y))&lt;br /&gt;
              &amp;#039;&amp;#039;&amp;#039;foreach&amp;#039;&amp;#039;&amp;#039; (Nachbar z von x)&lt;br /&gt;
                  queue.ADD(Kante(z, x))&lt;br /&gt;
  &amp;#039;&amp;#039;&amp;#039;function AC3 end&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 &amp;#039;&amp;#039;&amp;#039;function EntferneInkonsistenteWerte(x, y)&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
  &amp;#039;&amp;#039;// Liefert true, wenn Domäne D(x) reduziert wird&amp;#039;&amp;#039;&lt;br /&gt;
      &amp;#039;&amp;#039;&amp;#039;removed&amp;#039;&amp;#039;&amp;#039; = false&lt;br /&gt;
      &amp;#039;&amp;#039;&amp;#039;foreach&amp;#039;&amp;#039;&amp;#039; (Value v1 in D(x))&lt;br /&gt;
          &amp;#039;&amp;#039;&amp;#039;if&amp;#039;&amp;#039;&amp;#039;(Kein v2 in D(Y), so dass (x=v1, y=v2) alle Constraints zwischen (x,y) erfüllt)&lt;br /&gt;
              D(x).LÖSCHE(v1)&lt;br /&gt;
              removed = true&lt;br /&gt;
      return &amp;#039;&amp;#039;&amp;#039;removed&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
  &amp;#039;&amp;#039;&amp;#039;function EntferneInkonsistenteWerte end&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Der Algorithmus hat eine Worst-Case-Zeit-Komplexität von &amp;#039;&amp;#039;&amp;#039;O&amp;#039;&amp;#039;&amp;#039;(&amp;#039;&amp;#039;ed&amp;lt;sup&amp;gt;3&amp;lt;/sup&amp;gt;&amp;#039;&amp;#039;), Worst-Case-Speicher-Komplexität: &amp;#039;&amp;#039;&amp;#039;O&amp;#039;&amp;#039;&amp;#039;(&amp;#039;&amp;#039;e&amp;#039;&amp;#039;), wobei &amp;#039;&amp;#039;e&amp;#039;&amp;#039; die Anzahl der Kanten und &amp;#039;&amp;#039;d&amp;#039;&amp;#039; die Größe der größten Domäne ist.&lt;br /&gt;
&lt;br /&gt;
== Belege ==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;references/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Algorithmus]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Wiegels</name></author>
	</entry>
</feed>