Quelle est la complexité temporelle (ordre d'algorithme) d'un algorithme qui trouve le minimum local dans un graphique avec n
nœuds (ayant chaque nœud un maximum de d
voisins)?Complexité temporelle de l'algorithme Hill Climbing pour trouver local min/max dans un graphique
Détail: Nous avons un graphique avec n
nœuds. Chaque noeud du graphe a une valeur entière. Chaque noeud a un maximum de d
voisins. Nous recherchons un nœud ayant la valeur la plus faible parmi ses voisins. Le graphique est représenté par une liste d'adjacence. L'algorithme commence par sélectionner des nœuds aléatoires et, au sein de ces nœuds, il sélectionne le nœud avec une valeur minimale (disons le nœud u
). À partir du noeud u
, l'algorithme trouve un voisin v
, où value(v) < value(u)
. Ensuite, il continue avec v
et répète l'étape ci-dessus. L'algorithme se termine lorsque le nœud n'a aucun voisin avec une valeur inférieure. Quelle est la complexité temporelle de cet algorithme et pourquoi?
Pouvez-vous élaborer la question plus avant? Que comprenez-vous par "minimum local"? –