Tiefensuche

Animation der Tiefensuche in einem Baum

Tiefensuche (englisch depth-first search, DFS) ist in der Informatik ein Verfahren zum Suchen von Knoten in einem Graphen. Sie zählt zu den uninformierten Suchalgorithmen. Im Gegensatz zur Breitensuche wird bei der Tiefensuche zunächst ein Pfad vollständig in die Tiefe beschritten, bevor abzweigende Pfade beschritten werden[1]. Dabei sollen alle erreichbaren Knoten des Graphen besucht werden. Für Graphen mit potenziell wenigen, langen Pfaden bietet sich die beschränkte Tiefensuche an, bei der jeder Pfad nur bis zu einer bestimmten Tiefe beschritten wird.

Eine Verbesserung der Tiefensuche ist die iterative Tiefensuche.

Arbeitsweise

Die Tiefensuche ist ein uninformierter Suchalgorithmus, welche durch Expansion des jeweils ersten auftretenden Nachfolgeknotens im Graphen nach und nach vom Startknoten aus weiter in die Tiefe sucht. In welcher Reihenfolge die Nachfolger eines Knotens dabei bestimmt werden, hängt von der Repräsentation der Nachfolger ab. Bei der Repräsentation über eine Adjazenzliste mittels einer verketteten Liste werden beispielsweise die Knoten in der Reihenfolge ihres Eintrags in dieser Liste durchlaufen. Im oben angegebenen Bild wird implizit davon ausgegangen, dass die Nachfolger von links nach rechts ausgewählt werden.

Für ungerichtete Graphen sieht das Verfahren wie folgt aus: Zuerst wird ein Startknoten ausgewählt. Von diesem Knoten aus wird nun die erste Kante betrachtet und getestet, ob der gegenüberliegende Knoten schon entdeckt wurde bzw. das gesuchte Element ist. Ist dies noch nicht der Fall, so wird rekursiv für diesen Knoten die Tiefensuche aufgerufen, wodurch wieder der erste Nachfolger dieses Knotens expandiert wird. Diese Art der Suche wird solange fortgesetzt, bis das gesuchte Element entweder gefunden wurde oder die Suche bei einer Senke im Graphen angekommen ist und somit keine weiteren Nachfolgeknoten mehr untersuchen kann. An dieser Stelle kehrt der Algorithmus nun zum zuletzt expandierten Knoten zurück und untersucht den nächsten Nachfolger des Knotens. Sollte es hier keine weiteren Nachfolger mehr geben, geht der Algorithmus wieder Schritt für Schritt zum jeweiligen Vorgänger zurück und versucht es dort erneut. Ein Beispiel für die Anwendung der Tiefensuche auf einen Baum zeigt die Animation.

Die vier Typen von Kanten, die vom Startknoten 1 des gezeigten gerichteten Graphen definiert werden. Die schwarzen Kanten zeigen den Baum, den die Tiefensuche durchläuft.

Die Kanten des Graphen, die vom Algorithmus zum Durchlaufen des Graphen benutzt werden, werden als Baumkanten bezeichnet. Diejenigen Kanten, die nicht benutzt werden und von einem Knoten zu einem anderen Knoten im selben Teilbaum führen, der bei der Tiefensuche später besucht wird, heißen Vorwärtskanten. Diejenigen Kanten, die nicht benutzt werden und von einem Knoten zu einem anderen Knoten im selben Teilbaum führen, der bei der Tiefensuche bereits vorher besucht wurde, heißen Rückwärtskanten. Diejenigen Kanten, die „quer“ von einem Teilbaum zu einem anderen Teilbaum verlaufen, heißen Querkanten. Innerhalb des Tiefensuchbaums würde der Pfad zwischen zwei über eine Querkante verbundenen Knoten zunächst ein Auf- und dann ein Absteigen im Baum erfordern. Vorwärtskanten, Rückwärtskanten, Querkanten und Baumkanten ergeben insgesamt die Kantenmenge des Graphen.

Eine graphentheoretische Landkarte von Deutschland, Österreich und der Schweiz mit den Verbindungen zwischen einigen Städten. Dieses Beispiel ist ein ungerichteter Graph mit 10 Knoten.
Der Baum, welcher entsteht, wenn man Tiefensuche auf die Landkarte anwendet und in Hannover startet. Dieser Baum hat die Höhe 6. Daher hat die Tiefensuche in diesem Fall die maximale Rekursionstiefe 6.

Der Index der Rekursionstiefe der rekursiven Methode oder Prozedur für die Tiefensuche entspricht dem Knotenabstand des aktuell durchlaufenen Knotens vom Startknoten im in der rechten Abbildung gezeigten Baum. Dieser Index müsste, um zum Beispiel auf der Konsole ausgegeben zu werden, in einer Variablen gespeichert werden. Diese rekursive Methode oder Prozedur wird so oft aufgerufen, wie die Anzahl der Knoten des Graphen ist. Die Rekursion bricht ab, wenn der aktuell durchlaufene Knoten nur Nachbarknoten hat, die schon vorher durchlaufen wurden.

Im Beispiel mit den Städten (siehe oben) gibt es folgende rekursive Aufrufe:

  • Hannover (Startknoten, Rekursionstiefe 0)
  • Frankfurt (Nachbarknoten von Hannover, Rekursionstiefe 1)
  • Zürich (Nachbarknoten von Frankfurt, Rekursionstiefe 2)
  • München (Nachbarknoten von Zürich, Rekursionstiefe 3)
  • Stuttgart (Nachbarknoten von München, Rekursionstiefe 4)
  • Hamburg (Nachbarknoten von Stuttgart, Rekursionstiefe 5)
  • Mannheim (Nachbarknoten von Hamburg, Rekursionstiefe 6)
  • Dresden (Nachbarknoten von Stuttgart, Rekursionstiefe 5)
  • Wien (Nachbarknoten von München, Rekursionstiefe 4)
  • Berlin (Nachbarknoten von Wien, Rekursionstiefe 5)

Der Knotenabstand bezieht sich immer auf den Startknoten. Im links dargestellten ungerichteten Graphen ist es Hannover. Bei gerichteten Graphen ist der Knotenabstand zwischen zwei verschiedenen Knoten nicht unbedingt symmetrisch.

Der Baum, den die Tiefensuche durchläuft, ist ein Spannbaum des Graphen und hängt vom Startknoten ab. Es ist außerdem wichtig, ob es sich um einen gerichteten Graphen oder ungerichteten Graphen handelt.

Der Knotenabstand und die Rekursionstiefe ist nur für zusammenhängende Graphen definiert und hängt vom Startknoten ab. Für nicht zusammenhängende Graphen ist der Knotenabstand und die Rekursionstiefe nur innerhalb jeder Zusammenhangskomponente definiert.

Hinweis: Der in der Abbildung links oben mit den Städten gezeigte Graph ist ein ungerichteter Graph. Die Reihenfolge der durchlaufenen Knoten kann sich ändern, wenn stattdessen ein anderer Startknoten oder ein gerichteter Graph genommen wird, der nicht symmetrisch ist.

Algorithmen

  1. Bestimme den Knoten, an dem die Suche beginnen soll
  2. Expandiere den Knoten und speichere der Reihenfolge nach den kleinsten/größten (optional) noch nicht erschlossenen Nachfolger in einem Stack
  3. Rufe rekursiv für jeden der Knoten in dem Stack DFS auf
    • Falls das gesuchte Element gefunden wurde, brich die Suche ab und liefere ein Ergebnis
    • Falls es keine nicht erschlossenen Nachfolger mehr gibt, lösche den obersten Knoten aus dem Stack und rufe für den jetzt oberen Knoten im Stack DFS auf
DFS(node, goal)
{
    if (node == goal)
    {
        return node;
    }
    else
    {
        stack := expand (node)
        while (stack is not empty)
        {
            node' := pop(stack);
            DFS(node', goal);
        }
    }
}

Erzeugen des Tiefensuchwaldes

Der folgende rekursive Algorithmus in Pseudocode erzeugt den Tiefensuchwald eines Graphen G mittels Setzen von Discovery- und Finishing-Times und Färben der Knoten. In Anlehnung an Cormen et al. werden zunächst alle Knoten weiß gefärbt. Anschließend startet die Tiefensuche per Definition beim alphabetisch kleinsten Knoten und färbt diesen grau. Danach wird, wie oben beschrieben rekursiv dessen weißer Nachbar betrachtet und grau gefärbt. Existiert kein weißer Nachbar mehr, kommt es zum Backtracking, während dessen alle durchwanderten Knoten schwarz gefärbt werden.[2]

DFS(G)
    for each v of G // Alle Knoten weiß färben, Vorgänger auf nil setzen
    {
        col[v] = 'w';
        pi[v] = nil;
    }
    time = 0;
    for each u of G // Für alle weißen Knoten: DFS-visit aufrufen
    {
        if col[u] == 'w'
        DFS-visit(u);
    }
DFS-visit(u)
 1  col[u] = 'g';            // Aktuellen Knoten grau färben
 2  time++;                  // Zeitzähler erhöhen
 3  d[u] = time;             // Entdeckzeit des aktuellen Knotens setzen
 4  for each v of Adj[u]     // Für alle weißen Nachbarn des aktuellen Knotens
 5  {
 6      if col[v] == 'w'
 7      {
 8          pi[v] = u;       // Vorgänger auf aktuellen Knoten setzen
 9          DFS-visit(v);    // DFS-visit aufrufen
10      }
11      if col[v] == 'g'
12      {
13          // Zyklus entdeckt
14      }
15  }
16  col[u] = 's';            // Aktuellen Knoten schwarz färben
17  time++;
18  f[u] = time;             // Finishing-Time des aktuellen Knotens setzen

Den Zeitstempel (siehe Zeilen 2, 17, 18) kann man weiterhin für eine topologische Sortierung verwenden. Nachdem ein Knoten schwarz gefärbt wurde, wird er einer Liste, absteigend nach den Werten f[u] für die Zeitstempel, hinzugefügt und man erhält eine topologische Reihenfolge. Wird ein Zyklus (siehe Zeile 9) entdeckt, ist dies nicht mehr möglich.

Programmierung

Das folgende Beispiel in der Programmiersprache C# zeigt die Implementierung der Tiefensuche für einen gerichteten Graphen. Der gerichtete Graph wird als Klasse DirectedGraph deklariert. Die Methode DepthFirstSearch, die die Knoten durchläuft und in einer Liste speichert, verwendet einfache Rekursion. Bei der Ausführung des Programms wird die Methode Main verwendet, die die Liste der markierten Knoten auf der Konsole ausgibt.[3]

using System;
using System.Collections.Generic;

// Deklariert die Klasse für die Knoten des Graphen
class Node
{
	public int index;
	public string value;
	public List<Node> adjacentNodes = new List<Node>(); // Liste der Nachbarknoten
}

// Deklariert die Klasse für den gerichteten Graphen
class DirectedGraph
{
	// Diese Methode verbindet die Knoten startNode und targetNode miteinander.
	public void ConnectNodes(Node startNode, Node targetNode)
	{
		startNode.adjacentNodes.Add(targetNode);
	}
}

class Program
{
	// Diese Methode gibt die Liste der Knoten in der Form A, B, C, ... als Text zurück.
	public static string ToString(List<Node> traversedNodes)
	{
		string text = "";
		for (int i = 0; i < traversedNodes.Count; i++) // for-Schleife, die die Knoten durchläuft
		{
			text += traversedNodes[i].value + ", ";
		}
		text = text.Substring(0, text.Length - 2);
		return text;
	}
	
	// Diese Methode durchläuft die Knoten des gerichteten Graphen mit einer Tiefensuche
	public static void DepthFirstSearch(Node startNode, List<Node> traversedNodes)
	{
		traversedNodes.Add(startNode); // Fügt den aktuellen Knoten der Menge der markierten Knoten hinzu
		foreach (Node node in startNode.adjacentNodes) // foreach-Schleife, die alle benachbarten Knoten des Knotens durchläuft
		{
			if (!traversedNodes.Contains(node)) // Wenn der Knoten noch nicht markiert wurde
			{
				DepthFirstSearch(node, traversedNodes); // Rekursiver Aufruf der Methode mit dem Nachbarknoten als Startknoten
			}
		}
	}
	
	// Hauptmethode, die das Programm ausführt
	public static void Main(String[] args)
	{
		// Deklariert und initialisiert 4 Knoten
		Node node1 = new Node{index = 0, value = "A"};
		Node node2 = new Node{index = 1, value = "B"};
		Node node3 = new Node{index = 2, value = "C"};
		Node node4 = new Node{index = 3, value = "D"};
		
		// Erzeugt einen gerichteten Graphen
		DirectedGraph directedGraph = new DirectedGraph();
		
		// Verbindet Knoten des Graphen miteinander
		directedGraph.ConnectNodes(node1, node2);
		directedGraph.ConnectNodes(node1, node3);
		directedGraph.ConnectNodes(node2, node3);
		directedGraph.ConnectNodes(node3, node1);
		directedGraph.ConnectNodes(node3, node4);
		directedGraph.ConnectNodes(node4, node4);
		
		List<Node> traversedNodes = new List<Node>(); // Liste der Knoten für die Tiefensuche
		DepthFirstSearch(node3, traversedNodes); // Aufruf der Methode
		Console.WriteLine(ToString(traversedNodes)); // Ausgabe auf der Konsole
		
		Console.ReadLine();
	}
}

Hinweise: Für die Nachbarknoten wurde eine Liste als Datentyp verwendet, damit die Reihenfolge der durchlaufenen Knoten eindeutig ist und die Knoten in allen Ebenen von links nach rechts durchlaufen werden. Für den Datentyp Menge zum Beispiel muss das nicht der der Fall sein. Statt dem HashSet (Menge) visitedNodes kann auch eine Liste oder ein Array vom Typ bool (Boolesche Variable) verwendet werden, wie im Einzelnachweis gezeigt.[3]

Eigenschaften

Im Folgenden werden Speicherbedarf und Laufzeit des Algorithmus in Landau-Notation angegeben. Wir gehen außerdem von einem gerichteten Graphen aus.

Speicherplatz

Der Speicherbedarf des Algorithmus wird ohne den Speicherplatz für den Graphen, wie er übergeben wird, angegeben, denn dieser kann in verschiedenen Formen mit unterschiedlichem Speicherbedarf vorliegen, z. B. als verkettete Liste, als Adjazenzmatrix oder als Inzidenzmatrix.

Für die oben beschriebene Prozedur DFS(G) werden zunächst alle Knoten weiß gefärbt und die Referenzen für deren Vorgänger entfernt. Diese Informationen benötigt also für jeden Knoten konstanten Speicherplatz, also . Insgesamt ergibt sich ein linearer Speicherbedarf von , abhängig von der Anzahl der Knoten (englisch vertices). Der Speicherbedarf der Variable time ist mit konstantem gegenüber vernachlässigbar. Anschließend wird für jeden Knoten u die Prozedur DFS-visit(u) aufgerufen. Da es sich hierbei nur um Kontrollstrukturen handelt, tragen sie nicht zum Speicherbedarf bei.

Die Prozedur DFS-visit(u) arbeitet auf der bereits aufgebauten Speicherstruktur in der alle Knoten abgelegt sind und erweitert diese pro Knoten noch um die Entdeckzeit und die Finishing-Time, jeweils konstant . Das ändert nichts am bisherigen linearen Speicherbedarf . Da sonst in DFS-visit(u) keine weiteren Variablen mehr eingeführt werden, hat die Tiefensuche einen Speicherbedarf von .

Laufzeit

Falls der Graph als Adjazenzliste gespeichert wurde, müssen im Worst Case alle möglichen Pfade zu allen möglichen Knoten betrachtet werden. Damit beträgt die Laufzeit von Tiefensuche , wobei für die Anzahl der Knoten und für die Anzahl der Kanten im Graph stehen.[4]

Vollständigkeit

Falls ein Graph unendlich groß ist oder kein Test auf Zyklen durchgeführt wird, so ist die Tiefensuche nicht vollständig. Es kann also sein, dass ein Ergebnis – obwohl es existiert – nicht gefunden wird.

Optimalität

Tiefensuche ist insbesondere bei monoton steigenden Pfadkosten nicht optimal, da eventuell ein Ergebnis gefunden wird, zu welchem ein sehr viel längerer Pfad führt als zu einem alternativen Ergebnis. Dafür wird ein solches Ergebnis im Allgemeinen deutlich schneller gefunden als bei der in diesem Fall optimalen, aber sehr viel speicheraufwendigeren Breitensuche. Als Kombination von Tiefen- und Breitensuche gibt es die iterative Tiefensuche.

Anwendungen

Algorithmus, der Tiefensuche verwendet, um einen Irrgarten zu erzeugen.

Die Tiefensuche ist indirekt an vielen komplexeren Algorithmen für Graphen beteiligt. Beispiele:

  • Das Lösen von Rätseln mit nur einer Lösung, z. B. Irrgärten. Die Tiefensuche kann angepasst werden, um alle Lösungen für einen Irrgarten zu finden, indem nur Knoten auf dem aktuellen Pfad in die besuchte Menge aufgenommen werden.
  • Für das Erzeugen eines Irrgartens kann eine zufällige Tiefensuche verwendet werden.

Literatur

Commons: Tiefensuche – Sammlung von Bildern, Videos und Audiodateien
Wikibooks: Tiefensuche – Implementierungen in der Algorithmensammlung

Einzelnachweise

  1. Volker Turau: Algorithmische Graphentheorie. 3. Auflage. Oldenbourg Wissenschaftsverlag, München 2009, ISBN 978-3-486-59057-9, S. 94–98.
  2. Thomas H. Cormen, Charles Leiserson, Ronald L. Rivest, Clifford Stein: Algorithmen – Eine Einführung. 3. Auflage. Oldenbourg Wissenschaftsverlag, München 2010, ISBN 978-3-486-59002-9, S. 613–622.
  3. a b GeeksforGeeks: Depth First Search or DFS for a Graph
  4. Thomas Ottmann, Peter Widmayer: Algorithmen und Datenstrukturen. 5. Auflage. Spektrum Akademischer Verlag, Heidelberg 2012, ISBN 978-3-8274-2803-5, S. 589–668.
  5. John Hopcroft, Robert E. Tarjan: Efficient planarity testing. In: Journal of the Association for Computing Machinery. 21. Jahrgang, Nr. 4, 1974, S. 549–568, doi:10.1145/321850.321852.
  6. H. de Fraysseix, P. Ossona de Mendez, P. Rosenstiehl: Trémaux Trees and Planarity. In: International Journal of Foundations of Computer Science. 17. Jahrgang, Nr. 5, 2006, S. 1017–1030, doi:10.1142/S0129054106004248, arxiv:math/0610935.
  7. a b Sven Oliver Krumke, Hartmut Noltemeier: Graphentheoretische Konzepte und Algorithmen. 3. Auflage. Springer Vieweg, Wiesbaden 2012, ISBN 978-3-8348-1849-2, S. 152–157.

Read other articles:

American baseball player (1932–2019) This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: Tex Clevenger – news · newspapers · books · scholar · JSTOR (August 2019) (Learn how and when to remove this template message) Baseball player Tex ClevengerPitcherBorn: (1932-07-09)July 9, 1932Visalia, California, U.S.Died...

 

 

For Paramount+ original TV shows, see List of Paramount+ original programming. For films made available through the TVING content hub, see List of TVING original programming. This article lists all films, documentary films and specials produced for release on Paramount+, formerly known as CBS All Access, an American over-the-top subscription video on demand service owned and operated by Paramount Streaming, a division of Paramount Global. Original films Feature films Title Genre Release date...

 

 

Päijät-Häme Päijänne-TavastlandTavastia PäijänneRegionRegion Päijät-HämePäijät-Hämeen maakuntacode: fi is deprecated   (Finlandia)Landskapet Päijänne-Tavastlandcode: sv is deprecated   (Swedia) BenderaLambang kebesaranPäijät-Häme di peta FinlandiaNegaraFinlandiaProvinsi historisTavastiaIbukotaLahtiLuas • Total6.256,66 km2 (2,415,71 sq mi) • Luas daratan5.126,11 km2 (1,979,20 sq mi)Populasi (2019)&...

Listes de films américains ◄◄ 1935 1936 1937 1938 1939 1940 1941 1942 1943 ►► Liste (non exhaustive) de films américains sortis en 1939. Gone with the Wind remporte l'Oscar du meilleur film à la 12e cérémonie des Oscars organisée le 29 février 1940. (ordre alphabétique des titres en anglais) Titre comportant un nombre Titre Réalisateur Distribution Genre Notes $1000 a Touchdown James Patrick Hogan Joe E. Brown, Martha Raye, Eric Blore, Susan Hayward Comédie Paramount 2...

 

 

Sayaka SatoInformasi pribadiKebangsaanJepangLahir29 Maret 1991 (umur 33)Sendai, JepangTempat tinggalKanagawa, JepangTinggi171 m (561 ft 0 in)Berat70 kg (154 pon)PeganganKiriTunggal putriPeringkat tertinggi12 (10 November 2016)Peringkat saat ini416 (17 Maret 2020) Rekam medali Putri badminton Mewakili  Jepang Piala Uber 2018 Bangkok Women's team 2010 Kuala Lumpur Women's team 2012 Wuhan Women's team 2016 Kunshan Women's team Asian Games 2018 Jakarta...

 

 

Disambiguazione – Se stai cercando altri significati, vedi Coppa Libertadores 2012 (disambigua). Coppa Libertadores 2012Copa Santander Libertadores de América 2012 Competizione Coppa Libertadores Sport Calcio Edizione 53ª Organizzatore CONMEBOL Date 24 gennaio 2012 - 4 luglio 2012 Partecipanti 38 Risultati Vincitore  Corinthians(1º titolo) Secondo  Boca Juniors Semi-finalisti  Universidad de Chile Santos Statistiche Miglior marcatore Matías Alustiza Neymar (8 g...

1967 Italian comedy film ArabellaTheatrical release posterDirected byMauro BologniniWritten byGiorgio ArlorioAdriano BaraccoBrunello RondiProduced byMaleno MalenottiStarringVirna LisiJames FoxMargaret RutherfordTerry-ThomasCinematographyEnnio GuarnieriEdited byEraldo Da RomaMusic byEnnio MorriconeDistributed byUniversal PicturesRelease date 1967 (1967) Running time105 minutes (Italy)CountryItalyLanguageEnglish Arabella is an Italian comedy film in the English language, starring Virna Lis...

 

 

Sekretariat Komite Pusat Partai Komunis Uni Soviet Секретариат ЦК КПСС PimpinanStatusBadan pemerintahan pusat Partai Komunis Uni Soviet PemimpinSekretaris Umum Dipilih olehKomite Pusat Bertanggung jawab untukKomite Pusat AnggotaBeragamTempat bersidangLapangan Staraya, Moskwa, SFSR Rusia[1] L • BBantuan penggunaan templat ini Sekretariat Komite Pusat Partai Komunis Uni Soviet adalah sebuah badan yang bertanggung jawab untuk pemerintahan pusat dari partai tersebu...

 

 

MuşMunisipalitasMuşKoordinat: 38°44′00″N 41°29′28″E / 38.73333°N 41.49111°E / 38.73333; 41.49111Koordinat: 38°44′00″N 41°29′28″E / 38.73333°N 41.49111°E / 38.73333; 41.49111NegaraTurkiProvinsiMuşPemerintahan • WalikotaFeyat Asya (AKP)Luas[1] • Distrik2.604,14 km2 (100,546 sq mi)Ketinggian1.350 m (4,430 ft)Populasi (2012)[2] • Perkotaan81....

Почесні звання України Почесне звання України — державна нагорода України. Почесні звання України присвоюються особам, які працюють у відповідній галузі економічної та соціально-культурної сфери, як правило, не менше десяти років, мають високі трудові досягнення і п...

 

 

Election in Hawaii Main article: 1984 United States presidential election 1984 United States presidential election in Hawaii ← 1980 November 6, 1984 1988 →   Nominee Ronald Reagan Walter Mondale Party Republican Democratic Home state California Minnesota Running mate George H. W. Bush Geraldine Ferraro Electoral vote 4 0 Popular vote 185,050 147,154 Percentage 55.10% 43.82% County Results Reagan  50–60% President before election ...

 

 

فلوموكسيف الاسم النظامي (6R,7R)-7-[[2-(Difluoromethylsulfanyl)acetyl]amino]-3- [[1-(2-hydroxyethyl)tetrazol-5-yl]sulfanylmethyl]-7-methoxy-8-oxo-5-oxa-1-azabicyclo[4.2.0]oct-2-ene-2-carboxylic acid اعتبارات علاجية ASHPDrugs.com أسماء الدواء الدولية معرّفات CAS 99665-00-6 Y ك ع ت J01J01DC14 DC14 تصنيف منظمة الصحة العالمية المراقبة  [لغات أخرى]‏[1]  بوب ك�...

Software developer Wrightsoft Corp.Company typePrivateFounded1985HeadquartersLexington, Massachusetts, USAKey peopleBill Wright:President & CEOChris Edgren:Vice President Sales & MarketingMichael Shnitman:Vice President Software DevelopmentCharles S. Chip BarnabyVice President ResearchWebsitewww.wrightsoft.com Wrightsoft is a software development firm for heating, ventilation, and air conditioning (HVAC). Established in 1985,[1] Wrightsoft has served residential, commercial, a...

 

 

American Association of Colleges of NursingLogo of AACNAbbreviationAACNFormation1969Headquarters655 K Street, NW Suite 750 Washington, D.C., United StatesMembership 876 membersBoard ChairJean Giddens, PhD, RNPresident/CEODeborah E. Trautman, PhD, RNWebsitewww.aacnnursing.org The American Association of Colleges of Nursing (AACN) is a national organization of nurses in the United States that is dedicated to advancing nursing education. It was established in 1969, and represents more than 875 m...

 

 

第三十二届夏季奥林匹克运动会男子400米比賽比賽場館新国立竞技场日期2021年8月1日(预赛)2021年8月2日(半决赛)2021年8月5日(决赛)参赛选手48位選手,來自33個國家和地區冠军成绩43.85奖牌获得者01 ! 史蒂文·加德纳  巴哈马02 ! 安东尼·桑布拉诺  哥伦比亚03 ! 基拉尼·詹姆斯  格林纳达← 20162024 → 2020年夏季奥林匹克运动会田径比赛径赛1...

Questa voce sull'argomento dipinti è solo un abbozzo. Contribuisci a migliorarla secondo le convenzioni di Wikipedia. Segui i suggerimenti del progetto di riferimento. Hélène Fourment con due dei suoi figliAutorePeter Paul Rubens Data1636 Tecnicaolio su tela Dimensioni115×85 cm UbicazioneMusée du Louvre, Parigi Hélène Fourment con due dei suoi figli è un dipinto (115x85 cm) realizzato nel 1636 circa dal pittore Peter Paul Rubens. È conservato nel Musée du Louvre di Parigi...

 

 

عرق بارز من الكوارتز بين صخور خاضعة لعوامل الحت والتعرية العرق في الجيولوجيا عبارة عن تجمع متمايز لكتل من معدن متبلور داخل الصخور. تتشكل العروق عندما تُحمَل المكونات المعدنية من قبل المحاليل المائية داخل كتلة الصخرة ثم تحدث عليها عملية ترسيب؛ ويكون جريان الموائع الواقع و�...

 

 

Aeropuerto de Aarhus Aarhus Lufthavn IATA: AAR OACI: EKAH FAA: LocalizaciónUbicación Kolind, DinamarcaElevación 25Sirve a AarhusDetalles del aeropuertoTipo CivilPropietario Aarhus (municipio)Operador Aarhus Lufthavn A/SPistas DirecciónLargoSuperficie10L/28R2.777Asfalto10R/28L2.702AsfaltoMapa AAR / EKAH Ubicación en DinamarcaSitio web https://www.aar.dk/[editar datos en Wikidata] El Aeropuerto de Aarhus (IATA: AAR, OACI: EKAH) es un aeropuerto civil ubicado en Tirstrup, Din...

Lingua franca har två betydelser. I nutida språkvetenskapliga sammanhang betecknar det generellt ett språk som används vid kommunikation mellan människor som inte förstår varandras modersmål. Historiskt betecknar det också ett specifikt pidginspråk med samma funktion. Detta utvecklades i Medelhavsområdet under korstågstiden men är idag utdött.[1] Historia Termen lingua franca användes för första gången av franska och italienska korsfarare i medelhavsområdet för att kommuni...

 

 

American radio network This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: Salem Radio Network – news · newspapers · books · scholar · JSTOR (November 2022) (Learn how and when to remove this message) Salem Radio NetworkTypeRadio networkCountryUnited StatesOwnershipOwnerSalem Media GroupHistoryLaunch date2009Cov...