Heim > Backend-Entwicklung > C++ > Zählen Sie in C++ die Anzahl der ganzzahligen Punkte zwischen zwei Punkten

Zählen Sie in C++ die Anzahl der ganzzahligen Punkte zwischen zwei Punkten

WBOY
Freigeben: 2023-09-02 21:57:07
nach vorne
1055 Leute haben es durchsucht

Zählen Sie in C++ die Anzahl der ganzzahligen Punkte zwischen zwei Punkten

In diesem Tutorial schreiben wir ein Programm, das die Anzahl der ganzzahligen Punkte zwischen zwei gegebenen Punkten ermittelt.

Die Anzahl der Punkte zwischen zwei gegebenen Punkten beträgt gcd(abs(x2), abs(y1-y2)) – 1.

Wenn die Verbindungslinie parallel zur x-Achse verläuft, beträgt die Anzahl der ganzzahligen Punkte abs(y1 - y2) - 1.

Wenn die Verbindungslinie parallel zur y-Achse verläuft, beträgt die Anzahl der ganzzahligen Punkte abs(x1 - x2) - 1.

Wenn die x-Koordinaten zweier Punkte gleich sind, sind sie parallel zur x-Achse. Wenn die y-Koordinaten zweier Punkte gleich sind, sind sie parallel zur y-Achse.

Sehen wir uns ein Beispiel an.

Eingabe

pointOne = [1, 5]
pointTwo = [1, 3]
Nach dem Login kopieren

Ausgabe

1
Nach dem Login kopieren

Algorithmus

  • Zwei Punkte initialisieren.
  • Überprüfen Sie, ob sie parallel zur x-Achse sind.
  • Wenn sie parallel zur x-Achse sind, verwenden Sie die Formel abs(y1 - y2) - 1.
  • Überprüfen Sie, ob sie parallel zur y-Achse sind.
  • Wenn sie parallel zur y-Achse sind, verwenden Sie die Formel abs(x1 - x2) - 1.
  • Wenn sie zu keiner Achse parallel sind, verwenden Sie die Formel gcd(abs(x1-x2), abs(y1- y2)) - 1.
  • Berechnen Sie das Ergebnis und drucken Sie es aus.

Implementierung

Das Folgende ist die Implementierung des obigen Algorithmus in C++

#include <bits/stdc++.h>
using namespace std;
int gcd(int a, int b) {
   if (b == 0) {
      return a;
   }
   return gcd(b, a % b);
}
int getCount(int pointOne[], int pointTwo[]) {
   if (pointOne[0] == pointTwo[0]) {
      return abs(pointOne[1] - pointTwo[1]) - 1;
   }
   if (pointOne[1] == pointTwo[1]) {
      return abs(pointOne[0] - pointTwo[0]) - 1;
   }
   return gcd(abs(pointOne[0] - pointTwo[0]), abs(pointOne[1] - pointTwo[1])) - 1;
}
int main() {
   int pointOne[] = {1, 3}, pointTwo[] = {10, 12};
   cout << getCount(pointOne, pointTwo) << endl;
   return 0;
}
Nach dem Login kopieren

Ausgabe

Wenn Sie den obigen Code ausführen, erhalten Sie die folgenden Ergebnisse.

8
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonZählen Sie in C++ die Anzahl der ganzzahligen Punkte zwischen zwei Punkten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:tutorialspoint.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage