A* använder sig av en bäst-först sökning för att generellt minska kostnaden (distansen till målet) genom att välja noder baserat på prioritet. Algoritmen baserar sin prioritet med hjälp av den minst förväntade totala kostnad med hjälp av en additiv funktion av två andra funktioner.
- Kostnaden ifrån start till nuvarande nod
- Estimerad kostnad (baserad på distans) från nuvarande nod till målet
Den totala estimerade kostnaden av en nod som genomsöks beräknas och den minst kostsamma noden läggs till i sökvägen.
För att A* skall förbli optimal bör aldrig överestimera kostnaden för att nå målet, det vill säga att den är tillåtlig. (engelska: admissible).
Processen
Det första algoritmen gör är att söka igenom den stigen som mest sannolikt leder till målet. Det som skiljer bäst-först-sökning och andra giriga algoritmer från A* är att tar hänsyn till kostnaden av den redan täckta vägen, .
Algoritmen börjar med den första noden, och sparar en kö av noder som ska besökas. Nodernas sortering är baserade på deras värden , där lägst placeras först i kön. För varje steg i algoritmen tas noden med lägst i listan (det vill säga först i kön) bort. Efter det beräknas och för alla dess grannar och de i sin tur läggs till i kön. Detta repeteras tills målet (noden) är först i kön, det vill säga har lägst kostnad eller om kön blir tom (ingen lösning).
Exempel
Ett exempel av en A* algoritm söker igenom en graf av tunnelbanestationer (noder) sammankopplade av järnvägar (kanter). I detta exemplet baseras på den raka distansen (tänk flyg) mellan nuvarande position till målet. Algoritmen följer vänstra vägen tills den når där har lägre kostnad än , detta visar att algoritmen kan arbeta på flera vägar samtidigt.
Egenskaper
Precis som bredden-först-sökning är A* komplett och kommer alltid finna en lösning om sådan finns.
Om heuristik-funktionen är tillåtlig (ej överestimerarande), är A* själv tillåtlig och optimal såvida inte använder en sluten används.
A* är optimal för alla heuristiker . Detta betyder att ingen annan algoritm som använder sig av samma heuristik kommer besöka färre noder än A*.
Komplexitet
Tidskomplexiteten av A* är beroende av den valda heuristik-funktionen. Det värsta fallet med ett obegränsat sökutrymme är antalet utökande noder exponentiellt i djupet (engelska: length) av lösningen (den kortaste vägen) där är divisionsfaktorn (medelvärdet av kanter per nod). Detta antar att det finns en lösning.
Applikationer
A* är vanligen använd för det allmänna vägsökningsproblemet i applikationer som spel, men var originellt designat som en generell graf-navigerande algoritm.
Referenser
Strategi Solo vs Squad di Free Fire: Cara Menang Mudah!