suchen
HeimBackend-EntwicklungPython-TutorialDer K-te Faktor von N – ein O(sqrt n)-Algorithmus

Einführung

Kürzlich habe ich den Beitrag „Lerne die Big-O-Notation ein für alle Mal“ geschrieben. In diesem Beitrag gehe ich auf alle Arten der Big-O-Zeitnotation ein, die im Big-O-Spickzettel verfügbar sind. Und ich hätte nicht gedacht, dass es außer diesen sieben noch weitere Zeitnotationen geben würde.

Als ob das Universum selbst mich demütigen und sich über meine Unwissenheit lustig machen würde, stieß ich auf ein LeetCode-Problem mit einer Lösung von O(√n) Zeit. Was übersetzt werden könnte in O(N^1/2), wenn Sie verrückt sind.

Das Problem

Sie erhalten zwei positive ganze Zahlen n und k. Ein Faktor einer ganzen Zahl n ist als eine ganze Zahl i definiert, wobei n % i == 0.

Betrachten Sie eine Liste aller Faktoren von n, sortiert in aufsteigender Reihenfolge, geben Sie den k-ten Faktor in dieser Liste zurück oder geben Sie -1 zurück, wenn n weniger als k Faktoren hat.

Die offensichtliche Lösung

Nun, wenn Sie wie ich sind, war Ihr erster Gedanke, jede Zahl von 1 bis n durchzugehen, zu prüfen, ob es sich um einen Faktor handelt, und ihn zurückzugeben, wenn er im gewünschten k-Index liegt.

Der Code sieht so aus:

def getkthFactorOfN(n, k):
    result = 0
    for i in range(1, n + 1):
        if n % i == 0:
            result = result + 1
            if result == k:
                return i
    return -1

Das ist alles schön und gut, aber es ist „nur“ O(n). Schließlich gibt es nur eine Schleife und diese geht bis n 1.
Bei der Berücksichtigung der Zeitnotation wird jede andere Operation verworfen.

Aber, mein Freund, es gibt einen Haken.

Faktoren verstehen

Wenn man darüber nachdenkt, werden Faktoren ab einem bestimmten Punkt „gespiegelt“.

Nehmen Sie zum Beispiel die Zahl 81. Ihre Faktoren sind [1, 3, 9, 27], wobei:

  • 1 * 81 = 81
  • 3 * 27 = 81
  • 9 * 9 = 81
  • 27 * 3 = 81
  • 81 * 1 = 81

Wenn Sie die Zahl 9 nicht mitzählen, werden die Vorgänge einfach wiederholt und umgedreht. Wenn Sie n durch einen seiner Faktoren dividieren, erhalten Sie einen weiteren Faktor.
Erwarten Sie die Quadratwurzel von n, wo sie selbst quadriert ist (duh).

Mit diesem Wissen wissen wir jetzt, dass wir die Schleife nicht bis zu n-mal (mit range(1, n 1)) durchlaufen müssen, sondern einfach bis zu math.sqrt(n). Danach haben wir alle Faktoren, die wir brauchen!

Die nicht so offensichtliche Lösung

Da wir nun alles haben, was wir brauchen, müssen wir diese Schleife von 1 -> umwandeln. n bis 1 -> sqrt n.

Ich gebe einfach den Code hier ein und wir gehen die Zeilen eine nach der anderen durch.

def getkthFactorOfN(n, k):
    i = 1
    factors_asc = []
    factors_desc = []
    while i * i 



<p>Uff, es ist viel komplexer. Lassen Sie es uns aufschlüsseln:</p>

<p>Zuerst initialisieren wir i = 1. Diese Variable wird bei der Suche nach Faktoren als „Zahl, bei der wir uns gerade befinden“ verwendet.</p>

<p>Zweitens erstellen wir zwei Arrays: Faktoren_asc und Faktoren_desc. Der Zauber dabei ist, dass wir Faktoren zu „factors_asc“ hinzufügen – sie werden so benannt, weil sie automatisch in aufsteigender Reihenfolge angezeigt werden.<br>
Immer wenn wir etwas zu „factors_asc“ hinzufügen, teilen wir n durch es und fügen es zu „factors_desc“ hinzu. Ähnliche Logik hier; Sie werden bequem in absteigender Reihenfolge hinzugefügt.</p><p>Dann beginnen wir unsere Schleife. Hier habe ich es in „while i * i 

</p><p>Wir beginnen mit der Prüfung, ob die aktuelle Zahl ein Faktor ist (n % i == 0). Wenn ja, können wir es an unser Factors_asc-Array anhängen.</p>

<p>Als nächstes erhalten wir den „Umkehrfaktor“ von i. Wir können dies tun, indem wir prüfen, ob i != n // i, oder mit anderen Worten, ob es nicht die Wurzel ist. Dies liegt daran, dass die Wurzel nicht in beiden Arrays dupliziert werden darf. Ist dies nicht der Fall, erhalten wir den umgekehrten Faktor, indem wir n // i ausführen und das Ergebnis in Factors_desc.</p> anhängen

<p>Danach addieren wir 1 zu i und setzen unsere Schleife fort.</p>

<p>Nachdem die Schleife abgeschlossen ist, müssen wir über alle Fakultäten verfügen, die wir benötigen.</p>

<p>Wir beginnen mit der Prüfung, ob k in der ersten Hälfte einschließlich der Wurzel (die als Mitte interpretiert werden kann) liegt, mit if k 

</p><p>Wenn nicht, müssen wir die Anzahl der gefundenen Faktoren von k subtrahieren und erneut prüfen – mit k -= len(factors_asc) und wenn k 

</p><p>Wenn k innerhalb von „factors_desc“ liegt, erhalten Sie seinen Wert mit „factors_desk[-k]“ (vom letzten zum ersten).</p>

<p>Wenn alles fehlschlägt, geben Sie -1 zurück.</p>

<h2>
  
  
  Die Kurve
</h2>

<p>Wenn Sie sich fragen, wo im Kurvendiagramm es landet, liegt es zwischen <strong>O(n)</strong> und <strong>O(log n)</strong>, was besser als ersteres und schlechter ist als Letzteres. Hier ist eine Grafik:</p>

<p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/173598658415895.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="The Kth factor of N - an O(sqrt n) algorithm"><br>
<em>Verfügbar bei Mathspace</em></p>

<h2>
  
  
  Abschluss
</h2>

<p>Dies war eine Fahrt zum Entdecken und Forschen. Vielen Dank, dass Sie bis hierher gelesen haben.</p>

<p>Wenn Sie eine bessere Optimierung wünschen, können Sie die Variablen „factors_asc_len“ und „factors_desc_len“ erstellen und jedes Mal, wenn Sie einen Wert an diese Arrays anhängen, 1 hinzufügen, sodass die Methode len() nicht aufgerufen werden muss, da dies bei dieser Methode der Fall ist <strong>O(n)</strong>, sodass es Auswirkungen auf die Zeitnotation haben kann.</p>

<p>Viel Glück im Studium und bis zum nächsten Mal!</p>


          

            
        

Das obige ist der detaillierte Inhalt vonDer K-te Faktor von N – ein O(sqrt n)-Algorithmus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu findenSo verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu findenMar 05, 2025 am 09:58 AM

Dieses Tutorial zeigt, wie man Python verwendet, um das statistische Konzept des Zipf -Gesetzes zu verarbeiten, und zeigt die Effizienz des Lesens und Sortierens großer Textdateien von Python bei der Bearbeitung des Gesetzes. Möglicherweise fragen Sie sich, was der Begriff ZiPF -Verteilung bedeutet. Um diesen Begriff zu verstehen, müssen wir zunächst das Zipf -Gesetz definieren. Mach dir keine Sorgen, ich werde versuchen, die Anweisungen zu vereinfachen. Zipf -Gesetz Das Zipf -Gesetz bedeutet einfach: In einem großen natürlichen Sprachkorpus erscheinen die am häufigsten vorkommenden Wörter ungefähr doppelt so häufig wie die zweiten häufigen Wörter, dreimal wie die dritten häufigen Wörter, viermal wie die vierten häufigen Wörter und so weiter. Schauen wir uns ein Beispiel an. Wenn Sie sich den Brown Corpus in amerikanischem Englisch ansehen, werden Sie feststellen, dass das häufigste Wort "Th ist

So herunterladen Sie Dateien in PythonSo herunterladen Sie Dateien in PythonMar 01, 2025 am 10:03 AM

Python bietet eine Vielzahl von Möglichkeiten zum Herunterladen von Dateien aus dem Internet, die über HTTP über das Urllib -Paket oder die Anforderungsbibliothek heruntergeladen werden können. In diesem Tutorial wird erläutert, wie Sie diese Bibliotheken verwenden, um Dateien von URLs von Python herunterzuladen. Anfragen Bibliothek Anfragen ist eine der beliebtesten Bibliotheken in Python. Es ermöglicht das Senden von HTTP/1.1 -Anfragen, ohne die URLs oder die Formulierung von Postdaten manuell hinzuzufügen. Die Anforderungsbibliothek kann viele Funktionen ausführen, einschließlich: Formulardaten hinzufügen Fügen Sie mehrteilige Datei hinzu Greifen Sie auf Python -Antwortdaten zu Eine Anfrage stellen Kopf

Wie benutze ich eine schöne Suppe, um HTML zu analysieren?Wie benutze ich eine schöne Suppe, um HTML zu analysieren?Mar 10, 2025 pm 06:54 PM

In diesem Artikel wird erklärt, wie man schöne Suppe, eine Python -Bibliothek, verwendet, um HTML zu analysieren. Es beschreibt gemeinsame Methoden wie find (), find_all (), select () und get_text () für die Datenextraktion, die Behandlung verschiedener HTML -Strukturen und -Anternativen (SEL)

Bildfilterung in PythonBildfilterung in PythonMar 03, 2025 am 09:44 AM

Der Umgang mit lauten Bildern ist ein häufiges Problem, insbesondere bei Mobiltelefonen oder mit geringen Auflösungskamera-Fotos. In diesem Tutorial wird die Bildfilterungstechniken in Python unter Verwendung von OpenCV untersucht, um dieses Problem anzugehen. Bildfilterung: Ein leistungsfähiges Werkzeug Bildfilter

Wie man mit PDF -Dokumenten mit Python arbeitetWie man mit PDF -Dokumenten mit Python arbeitetMar 02, 2025 am 09:54 AM

PDF-Dateien sind für ihre plattformübergreifende Kompatibilität beliebt, wobei Inhalte und Layout für Betriebssysteme, Lesegeräte und Software konsistent sind. Im Gegensatz zu Python Processing -Klartextdateien sind PDF -Dateien jedoch binäre Dateien mit komplexeren Strukturen und enthalten Elemente wie Schriftarten, Farben und Bilder. Glücklicherweise ist es nicht schwierig, PDF -Dateien mit Pythons externen Modulen zu verarbeiten. In diesem Artikel wird das PYPDF2 -Modul verwendet, um zu demonstrieren, wie Sie eine PDF -Datei öffnen, eine Seite ausdrucken und Text extrahieren. Die Erstellung und Bearbeitung von PDF -Dateien finden Sie in einem weiteren Tutorial von mir. Vorbereitung Der Kern liegt in der Verwendung von externem Modul PYPDF2. Installieren Sie es zunächst mit PIP: pip ist p

Wie kann man mit Redis in Django -Anwendungen zwischenstrichenWie kann man mit Redis in Django -Anwendungen zwischenstrichenMar 02, 2025 am 10:10 AM

Dieses Tutorial zeigt, wie man Redis Caching nutzt, um die Leistung von Python -Anwendungen zu steigern, insbesondere innerhalb eines Django -Frameworks. Wir werden Redis -Installation, Django -Konfiguration und Leistungsvergleiche abdecken, um den Vorteil hervorzuheben

Einführung des natürlichen Sprach -Toolkits (NLTK)Einführung des natürlichen Sprach -Toolkits (NLTK)Mar 01, 2025 am 10:05 AM

Die natürliche Sprachverarbeitung (NLP) ist die automatische oder semi-automatische Verarbeitung der menschlichen Sprache. NLP ist eng mit der Linguistik verwandt und hat Verbindungen zur Forschung in kognitiven Wissenschaft, Psychologie, Physiologie und Mathematik. In der Informatik

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?Mar 10, 2025 pm 06:52 PM

Dieser Artikel vergleicht TensorFlow und Pytorch für Deep Learning. Es beschreibt die beteiligten Schritte: Datenvorbereitung, Modellbildung, Schulung, Bewertung und Bereitstellung. Wichtige Unterschiede zwischen den Frameworks, insbesondere bezüglich des rechnerischen Graps

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

PHPStorm Mac-Version

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.