Maison > Article > développement back-end > Pourquoi est-ce que j'obtiens des distances incorrectes lorsque j'utilise des itérateurs pour calculer les distances entre les points ?
Utiliser correctement les itérateurs pour les calculs de distance
Vous rencontrez une erreur dans votre code lorsque vous essayez de calculer les distances entre des points stockés dans un vecteur. Il semble que le problème réside dans la façon dont vous utilisez l'itérateur.
Votre code utilise des itérateurs std::vector, qui sont des pointeurs vers des éléments du vecteur. Cependant, vous transmettez ces itérateurs directement à la fonction de distance, qui attend des pointeurs vers les objets ponctuels eux-mêmes. Cette incompatibilité entraîne des résultats incorrects.
Pour résoudre ce problème, vous disposez de deux options :
Option 1 : déréférencer les itérateurs
Vous pouvez déréférencer les itérateurs itérateurs pour obtenir des références aux objets ponctuels correspondants. Cela peut être fait en utilisant l'opérateur *. Voici le code modifié :
<code class="C++">for (ii = po.begin(); ii != po.end(); ii++) { for (jj = po.begin(); jj != po.end(); jj++) { cout << distance(*ii, *jj) << " "; } }</code>
Option 2 : Utiliser des références dans la fonction
Vous pouvez également modifier votre fonction de distance pour prendre directement des références pour pointer des objets :
<code class="C++">float distance(const point& p1, const point& p2) { return sqrt((p1.x - p2.x)*(p1.x - p2.x) + (p1.y - p2.y)*(p1.y - p2.y)); }</code>
De cette façon, vous pouvez appeler directement la fonction de distance avec des itérateurs :
<code class="C++">for (ii = po.begin(); ii != po.end(); ii++) { for (jj = po.begin(); jj != po.end(); jj++) { cout << distance(*ii, *jj) << " "; } }</code>
En utilisant l'une de ces méthodes, vous devriez obtenir les calculs de distance corrects entre des paires de points dans votre vecteur.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!