Inhaltsverzeichnis
Methoden, um die Lösung zu finden
Brute-Force-Methode
Beispiel
Ausgabe
Effiziente Methode
Erläuterung des obigen Codes
Fazit
Heim Backend-Entwicklung C++ Finden Sie mit C++ Paare positiver und negativer Werte in einem Array

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

Sep 20, 2023 pm 09:09 PM
c语言 数组 Positive und negative Wertepaare

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!

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Verwendung der Typedef-Struktur in der C-Sprache Verwendung der Typedef-Struktur in der C-Sprache May 09, 2024 am 10:15 AM

Verwendung der Typedef-Struktur in der C-Sprache

Was bedeutet real in der C-Sprache? Was bedeutet real in der C-Sprache? May 09, 2024 pm 12:06 PM

Was bedeutet real in der C-Sprache?

So implementieren Sie die Power-Funktion in der C-Sprache So implementieren Sie die Power-Funktion in der C-Sprache May 09, 2024 pm 11:33 PM

So implementieren Sie die Power-Funktion in der C-Sprache

Was tun, wenn in scanf in der C-Sprache ein Fehler auftritt? Was tun, wenn in scanf in der C-Sprache ein Fehler auftritt? May 09, 2024 am 11:39 AM

Was tun, wenn in scanf in der C-Sprache ein Fehler auftritt?

Was bedeutet reg in der C-Sprache? Was bedeutet reg in der C-Sprache? May 09, 2024 am 09:57 AM

Was bedeutet reg in der C-Sprache?

So verwenden Sie ElemType in der C-Sprache So verwenden Sie ElemType in der C-Sprache May 09, 2024 pm 12:03 PM

So verwenden Sie ElemType in der C-Sprache

So verwenden Sie Inline in C-Sprache So verwenden Sie Inline in C-Sprache May 09, 2024 am 10:12 AM

So verwenden Sie Inline in C-Sprache

Die Rolle von Scanfs in der C-Sprache Die Rolle von Scanfs in der C-Sprache May 09, 2024 am 11:30 AM

Die Rolle von Scanfs in der C-Sprache

See all articles