suchen

Hammerlisten

Dec 30, 2024 pm 04:34 PM

Hammering lists

Wöchentliche Herausforderung 301

Jede Woche verschickt Mohammad S. Anwar die Weekly Challenge, eine Chance für uns alle, Lösungen für zwei wöchentliche Aufgaben zu finden. Meine Lösungen werden zunächst in Python geschrieben und dann in Perl konvertiert. Es ist eine großartige Möglichkeit für uns alle, etwas Codierung zu üben.

Herausforderung, meine Lösungen

Aufgabe 1: Größte Zahl

Aufgabe

Sie erhalten eine Liste positiver Ganzzahlen, @ints.

Schreiben Sie ein Skript, um alle Elemente in der angegebenen Liste so anzuordnen, dass sie die größte Zahl bilden, und geben Sie diese zurück.

Meine Lösung

Vielleicht überdenke ich es, aber das ist nicht so einfach, wie es sich anhört.

Eine Möglichkeit wäre, alle Permutationen zu berechnen und zu sehen, welche Zahl am größten ist. Dies wird jedoch ressourcenintensiv, je mehr Ganzzahlen wir hinzufügen. Wenn ich dreizehn ganze Zahlen hätte, gäbe es über 6 Milliarden Permutationen. Daher schließe ich dies als mögliche Lösung aus.

Also liegt es nahe, die Ganzzahlen zu sortieren, zu kombinieren und das Ergebnis auszugeben. Da Python Strings und Integer-Zahlen unterschiedlich behandelt, muss ich die sortierte Liste in Strings umwandeln, diese verknüpfen und wieder in eine Integer-Zahl umwandeln.

def largest_number(ints: list) -> int:
    sorted_ints = sorted(ints, key=cmp_to_key(number_sort), reverse=True)
    return int(''.join(map(str, sorted_ints)))

Beim Sortieren ist das etwas kompliziert. Im zweiten bereitgestellten Beispiel können wir sehen, dass 3, 30 und 34 alle gegebene ganze Zahlen sind. Dabei weiß ich, dass man die größte Zahl erhält, wenn man die Artikel (von der höchsten zur niedrigsten) 34, 3 und 30 bestellt.

Für meine Funktion „number_sort“ konvertiere ich die Ganzzahlen in Zeichenfolgen, s1 und s2. Ich habe dann die ganze Zahl c1, die die Verkettung von s1 und s2 ist, während c2 die Verkettung von s2 und s1 ist.

Wenn c1 kleiner als c2 ist, gebe ich -1 zurück. Wenn sie größer ist, gebe ich 1 zurück. Wenn sie gleich sind, gebe ich 0 zurück. Die Sortierfunktion verwendet diese Informationen, um die Liste nach Bedarf zu sortieren.

def number_sort(i1: int, i2: int) -> int:
    s1 = str(i1)
    s2 = str(i2)

    c1 = int(s1 + s2)
    c2 = int(s2 + s1)

    if c1  c2:
        return 1

    return 0

Der Perl-Code ist viel einfacher :)

sub number_sort() {
    return "$a$b"  "$b$a";
}

Beispiele

$ ./ch-1.py 20 3
320

$ ./ch-1.py 3 30 34 5 9
9534330

Aufgabe 2: Hamming-Distanz

Aufgabe

Sie erhalten ein Array von Ganzzahlen, @ints.

Schreiben Sie ein Skript, um die Summe der Hamming-Abstände zwischen allen Ganzzahlpaaren im angegebenen Array von Ganzzahlen zurückzugeben.

Der Hamming-Abstand zwischen zwei ganzen Zahlen ist die Anzahl der Stellen, an denen sich ihre binären Darstellungen unterscheiden.

Meine Lösung

In der vorherigen Aufgabe habe ich erwähnt, wie Python ganze Zahlen und Zeichenfolgen als unterschiedliche Typen behandelt. Einer der Vorteile von Perl besteht darin, dass uns gesagt wird, dass wir uns praktisch keine Gedanken über die Typisierung von Variablen machen müssen. Auch wenn sie intern unterschiedlich gespeichert sind, weiß Perl, was zu tun ist.

In Perl 5.10 und Perl 5.16 (wo ich den Großteil meiner Perl-Entwicklung durchgeführt habe) gibt es zwei bemerkenswerte Ausnahmen. Eines ist das JSON-Modul, das „10“ für eine Zeichenfolge und 10 für eine Ganzzahl ausgibt.

Das andere sind bitweise Operationen. Von der Perlop-Seite, 105 | 150 (zwei ganze Zahlen) ist 255, während „105“ | „150“ (zwei Zeichenfolgen) ist 155.

Deshalb war ich angenehm überrascht, als ich die Perlop-Seite noch einmal las und sah, dass dies in einer späteren Version von Perl behoben wurde. Es verfügt jetzt über die bitweise Funktion, die in Perl 5.22 experimentell und in Perl 5.28 verfügbar ist. Dadurch wird sichergestellt, dass bitweise Operatoren die Werte immer als Ganzzahl behandeln und stringbasierte bitweise Operatoren über neue Operatoren verfügen.

Wie auch immer, zurück zur eigentlichen Aufgabe. Dazu berechne ich alle Kombinationen zweier Ganzzahlen. Für jede Kombination führe ich eine XOR-Verknüpfung (exklusives Oder) der beiden Werte durch, konvertiere sie in Binärwerte und zähle die Anzahl der Einsen in der Binärdarstellung.

def largest_number(ints: list) -> int:
    sorted_ints = sorted(ints, key=cmp_to_key(number_sort), reverse=True)
    return int(''.join(map(str, sorted_ints)))

Beispiele

def number_sort(i1: int, i2: int) -> int:
    s1 = str(i1)
    s2 = str(i2)

    c1 = int(s1 + s2)
    c2 = int(s2 + s1)

    if c1  c2:
        return 1

    return 0

Das obige ist der detaillierte Inhalt vonHammerlisten. 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
Was ist Python Switch Anweisung?Was ist Python Switch Anweisung?Apr 30, 2025 pm 02:08 PM

In dem Artikel wird die in Version 3.10 eingeführte "Match" -serklärung von Python erörtert, die als Äquivalent zum Wechseln von Aussagen in anderen Sprachen dient. Es verbessert die Code-Lesbarkeit und bietet Leistungsvorteile gegenüber herkömmlichen IF-ELIF-EL

Was sind Ausnahmegruppen in Python?Was sind Ausnahmegruppen in Python?Apr 30, 2025 pm 02:07 PM

Ausnahmegruppen in Python 3.11 ermöglichen die gleichzeitige Behandlung mehrerer Ausnahmen, wodurch die Fehlermanagement in gleichzeitigen Szenarien und komplexen Vorgängen verbessert wird.

Was sind Funktionsanmerkungen in Python?Was sind Funktionsanmerkungen in Python?Apr 30, 2025 pm 02:06 PM

Funktionsanmerkungen in Python Fügen Sie Metadaten zu Funktionen für Typprüfungen, Dokumentation und IDE -Unterstützung hinzu. Sie verbessern die Lesbarkeit, die Wartung der Code und die API -Entwicklung, die Datenwissenschaft und die Erstellung der Bibliothek von entscheidender Bedeutung.

Was sind Unit -Tests in Python?Was sind Unit -Tests in Python?Apr 30, 2025 pm 02:05 PM

In dem Artikel werden Unit -Tests in Python, deren Vorteile und wie man sie effektiv schreibt, erläutert. Es zeigt Werkzeuge wie Unittest und PyTest zum Testen.

Was sind Zugriffsspezifizierer in Python?Was sind Zugriffsspezifizierer in Python?Apr 30, 2025 pm 02:03 PM

In Artikel werden Zugriffsspezifizierer in Python erörtert, die benennende Konventionen verwenden, um die Sichtbarkeit von Klassenmitgliedern und nicht die strenge Durchsetzung anzuzeigen.

Was ist __init __ () in Python und wie spielt Selbst darin eine Rolle?Was ist __init __ () in Python und wie spielt Selbst darin eine Rolle?Apr 30, 2025 pm 02:02 PM

In Artikel wird die Methode von Python \ _ \ _ init \ _ \ _ () und die Rolle von Self bei der Initialisierung von Objektattributen erörtert. Andere Klassenmethoden und die Auswirkungen der Vererbung auf \ _ \ _ init \ _ \ _ () sind ebenfalls abgedeckt.

Was ist der Unterschied zwischen @ClassMethod, @StaticMethod und Instance -Methoden in Python?Was ist der Unterschied zwischen @ClassMethod, @StaticMethod und Instance -Methoden in Python?Apr 30, 2025 pm 02:01 PM

In dem Artikel werden die Unterschiede zwischen @ClassMethod, @StaticMethod und Instance -Methoden in Python erörtert und ihre Eigenschaften, Anwendungsfälle und Vorteile beschrieben. Es wird erläutert, wie Sie den richtigen Methodentyp basierend auf der erforderlichen Funktionalität und DA auswählen

Wie können Sie Elemente an ein Python -Array anhängen?Wie können Sie Elemente an ein Python -Array anhängen?Apr 30, 2025 am 12:19 AM

Inpython, youAppendElementStoAlistusedtheAppend () Methode.1) UseAppend () ForsingleElelements: my_list.append (4) .2) usextend () oder = formulnElements: my_list.extend (andere_list) ormy_list = [4,5,6] .3) useInSert () FORSPECIFIFICISPositionen: my_list.insert (1,5) .Beaware

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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor