Heim > Backend-Entwicklung > C++ > Hauptteil

Finden Sie mit C++ Paare positiver und negativer Werte in einem Array

王林
Freigeben: 2023-09-20 21:09:03
nach vorne
794 Leute haben es durchsucht

Finden Sie mit C++ Paare positiver und negativer Werte in einem Array

In diesem Artikel haben wir ein Array mit verschiedenen Elementen. Wir müssen die Paare positiver und negativer Werte im Array mit demselben absoluten Wert drucken und sie in sortierter Reihenfolge drucken, z. B.:

Input : arr[] = { 1, -1, 11, 12, 56, 77, -56, -12, -88}
Output : -1 1 -12 12 -56 56

Input : arr[] = {30, 40, 50, 77, -51, -50, -40}
Output : -40 40 -50 50
Nach dem Login kopieren

Methoden, um die Lösung zu finden

Die erste Methode, an die wir dachten, war die Brute-Force-Methode Und dann haben wir auch eine Methode namens Hocheffizienzmethode entwickelt. Wir werden beide Methoden besprechen.

Brute-Force-Methode

Bei dieser Methode durchlaufen wir das Array mit einem Index und finden denselben absoluten Wert, aber einen anderen Index.

Beispiel

#include<bits/stdc++.h>
using namespace std;

int main() {
   int arr[] = { 1, -1, 11, 12, 56, 77, -56, -12, -88 };
   int n = sizeof(arr)/sizeof(int); // size of our array.
   vector<int> nums; // the present pairs.

   for(int i = 0; i < n; i++) {
      for(int j = i+1; j < n; j++) {
         if(abs(arr[j]) == abs(arr[i])) { // finding the pairs.
            nums.push_back(abs(arr[i]));
            break;
            // if we found the pair then we can just break as there are distinct elements in the array.
         }
      }
   }
   sort(nums.begin(), nums.end());
   for(auto x : nums) // printing the pairs.
      cout << -x << " " << x << " ";
}
Nach dem Login kopieren

Ausgabe

-1 1 -12 12 -56 56
Nach dem Login kopieren

Bei diesem Ansatz verwenden wir zwei Schleifen, um das Array zu durchlaufen und ein anderes Element zu finden. Wenn wir ein anderes Element finden, springen wir aus der inneren Schleife, um den Code zu beschleunigen. Jetzt verwenden wir zwei for-Schleifen und die Gesamtzeitkomplexität beträgt O(N*N). N ist die Größe des gegebenen Arrays, funktioniert gut für niedrigere Einschränkungen, aber nicht gut für höhere Einschränkungen, daher werden wir jetzt einen anderen Ansatz diskutieren.

Effiziente Methode

Bei dieser Methode verwenden wir eine Hash-Map, was unsere Zeitkomplexität erheblich reduziert.

Beispiel

#include<bits/stdc++.h>
using namespace std;
int main() {
   int arr[] = { 4, 8, 9, -4, 1, -1, -8, -9 };
   int n = sizeof(arr)/sizeof(int); // size of our array.
   map<int, int> found; // going to store the count of numbers found.
   vector<int> nums; // the present pairs.
   for(int i = 0; i < n; i++)
      found[abs(arr[i])]++; // increasing the frequency of abs(arr[i]).
   for(auto x : found) { // traversing the map.
      if(x.second == 2) // if any numbers frequency is two then push it to nums.
         nums.push_back(x.first);
   }
   for(auto x : nums) // printing the pairs.
      cout << -x << " " << x << " ";
}
Nach dem Login kopieren

Ausgabe

-1 1 -4 4 -8 8 -9 9
Nach dem Login kopieren

Erläuterung des obigen Codes

Bei diesem Ansatz verwenden wir eine Hashmap, um die Häufigkeit von Zahlen zu speichern; während wir über das Array iterieren, aktualisieren wir nun die Häufigkeit des absoluten Werts des aktuellen Elements. Da Sie wissen, dass alle Paare den Wert 2 haben, durchqueren wir die Karte.

Wenn die Häufigkeit einer Zahl 2 beträgt, speichern wir sie in Zahlen und geben die Werte schließlich in sortierter Reihenfolge aus. (Da die Karte Zahlen in sortierter Reihenfolge enthält, müssen wir den numerischen Vektor nicht sortieren).

Fazit

In diesem Artikel haben wir das Problem gelöst, Paare positiver und negativer Werte in einem Array mithilfe von Hashing-Techniken zu finden. Wir haben auch ein C++-Programm zur Lösung dieses Problems und einen vollständigen Weg zur Lösung dieses Problems (normal und effizient) gelernt. Wir können das gleiche Programm in anderen Sprachen wie C, Java, Python und anderen Sprachen schreiben. Wir hoffen, dass dieser Artikel für Sie hilfreich war.

Das obige ist der detaillierte Inhalt vonFinden Sie mit C++ Paare positiver und negativer Werte in einem Array. 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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!