


Die kleinste ganze Zahl, die jedes Element in einem bestimmten Array teilt > 1: unter Verwendung von C++
In diesem Artikel erhalten wir ein Array von ganzen Zahlen und müssen die kleinste Zahl größer als 1 finden, die alle Elemente im Array teilt. Betrachten wir zum Beispiel ein Beispielarray [30, 90, 15, 45, 165].
vector<int> arr = {30, 90, 15, 45, 165}; result = solve(arr);
Jetzt können wir den größten gemeinsamen Teiler (GCD) der Arrays ermitteln. Wenn das Ergebnis 1 ist, was bedeutet, dass nur 1 das gesamte Array teilen kann, können wir -1 oder „Nicht möglich“ zurückgeben. Wenn das Ergebnis eine ganze Zahl ist, dann teilt diese ganze Zahl das gesamte Array. Diese Ganzzahl ist jedoch möglicherweise nicht die kleinste Ganzzahl, die das gesamte Array teilt. Interessanterweise teilen Faktoren dieser ganzen Zahl auch das gesamte Array, was Sinn macht. Wenn wir also den kleinsten Faktor dieser ganzen Zahl (GCD) finden können, haben wir die kleinste ganze Zahl, die das gesamte Array teilt. Kurz gesagt, wir müssen den größten gemeinsamen Teiler (GCD) der Arrays finden und dann ist der kleinste Faktor unsere Antwort.
Die chinesische Übersetzung vonBeispiel
lautet:Beispiel
Der folgende C++-Code kann eine kleinste ganze Zahl größer als 1 finden, die alle Elemente im Array teilen kann. Dies kann erreicht werden, indem der größte gemeinsame Teiler einer Liste von Elementen ermittelt wird -
#include <iostream> #include <vector> #include <algorithm> using namespace std; int divisor(int x) { if (x%2 == 0) { return 2; } for (int i=3;i*i<=x;i+=2) { if (x%i == 0) { return i; } } return x; } int solve(vector<int> arr) { int gcd = 0; for (int i=0;i<arr.size();i++) { gcd = __gcd(gcd, arr[i]); } return divisor(gcd); } int main() { vector<int> arr = {30, 90, 15, 45, 165}; cout << solve(arr); return 0; }
Ausgabe
3
Beispiel
lautet:Beispiel
Bei vielen Abfragen wird die Suche nach den Primfaktoren einer Zahl wiederholt. Mit der Siebmethode können wir die Primfaktoren einer Zahl berechnen.
In C++ ist eine weitere Implementierungsmethode zum Finden der kleinsten Zahl größer als 1 wie folgt:
#include <iostream> #include <vector> #include <algorithm> using namespace std; const int MAX = 100005; vector<int> prime(MAX, 0); void sieve() { prime[0] = 1; prime[1] = -1; for (int i=2; i*i<MAX;i++) { if (prime[i] == 0) { for (int j=i*2;j<MAX;j+=i) { if (prime[j] == 0) { prime[j] = i; } } } } for (int i=2; i<MAX;i++) { if (!prime[i]) { prime[i] = i; } } } int solve(vector<int> arr) { int gcd = 0; for (int i=0; i<arr.size();i++) { gcd = __gcd(gcd, arr[i]); } return prime[gcd]; } int main() { sieve(); vector<int> arr = { 30, 90, 15, 45, 165 }; cout << solve(arr); return 0; }
Ausgabe
3
Fazit
Wir haben die sqrt(n)-Methode verwendet, um den Mindestfaktor zu ermitteln. Dies kann optimiert werden, ich überlasse es Ihnen, es zu versuchen. Die Zeitkomplexität beträgt O(sqrt(n)). Bei der zweiten Methode entspricht die zeitliche Komplexität der der Siebmethode, also O(nlog(log(n))). Beachten Sie, dass wir die Obergrenze der Siebmethode basierend auf der von uns festgelegten globalen Variablen MAX ermitteln können.
Das obige ist der detaillierte Inhalt vonDie kleinste ganze Zahl, die jedes Element in einem bestimmten Array teilt > 1: unter Verwendung von C++. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



C Sprachdatenstruktur: Die Datenrepräsentation des Baumes und des Diagramms ist eine hierarchische Datenstruktur, die aus Knoten besteht. Jeder Knoten enthält ein Datenelement und einen Zeiger auf seine untergeordneten Knoten. Der binäre Baum ist eine besondere Art von Baum. Jeder Knoten hat höchstens zwei Kinderknoten. Die Daten repräsentieren structTreenode {intdata; structTreenode*links; structTreenode*rechts;}; Die Operation erstellt einen Baumtraversalbaum (Vorbereitung, in Ordnung und späterer Reihenfolge) Suchbauminsertion-Knoten Lösches Knotendiagramm ist eine Sammlung von Datenstrukturen, wobei Elemente Scheitelpunkte sind, und sie können durch Kanten mit richtigen oder ungerechten Daten miteinander verbunden werden, die Nachbarn darstellen.

In diesem Artikel werden die C -Standard -Vorlagenbibliothek (STL) erläutert, die sich auf seine Kernkomponenten konzentriert: Container, Iteratoren, Algorithmen und Funktoren. Es wird beschrieben, wie diese interagieren, um die generische Programmierung, die Verbesserung der Codeeffizienz und die Lesbarkeit t zu ermöglichen

Dieser Artikel beschreibt die effiziente Verwendung von STL -Algorithmus in c. Es betont die Auswahl der Datenstruktur (Vektoren vs. Listen), Algorithmus -Komplexitätsanalyse (z. B. std :: sortieren vs. std :: partial_sort), Iteratoranwendungen und parallele Ausführung. Häufige Fallstricke wie

In diesem Artikel wird die effektive Ausnahmebehandlung in C, Covering Try, Catch und Wurp Mechanics, beschrieben. Es betont Best Practices wie Raii, die Vermeidung unnötiger Fangblöcke und die Protokollierung von Ausnahmen für robusten Code. Der Artikel befasst sich auch mit Perf

Artikel erörtert den effektiven Einsatz von RValue -Referenzen in C für Bewegungssemantik, perfekte Weiterleitung und Ressourcenmanagement, wobei Best Practices und Leistungsverbesserungen hervorgehoben werden. (159 Charaktere)

Die Wahrheit über Probleme mit der Dateibetrieb: Dateiöffnung fehlgeschlagen: unzureichende Berechtigungen, falsche Pfade und Datei besetzt. Das Schreiben von Daten fehlgeschlagen: Der Puffer ist voll, die Datei ist nicht beschreibbar und der Speicherplatz ist nicht ausreichend. Andere FAQs: Langsame Dateitraversal, falsche Textdateicodierung und Binärdatei -Leser -Fehler.

C 20 -Bereiche verbessern die Datenmanipulation mit Ausdruckskraft, Komposition und Effizienz. Sie vereinfachen komplexe Transformationen und integrieren sich in vorhandene Codebasen, um eine bessere Leistung und Wartbarkeit zu erhalten.

In dem Artikel wird die Verwendung von Move Semantics in C erörtert, um die Leistung zu verbessern, indem unnötiges Kopieren vermieden wird. Es umfasst die Implementierung von Bewegungskonstruktoren und Zuordnungsbetreibern unter Verwendung von STD :: MOVE
