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!

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

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

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.

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.

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

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.

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

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


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

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

Heißer Artikel

Heiße Werkzeuge

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
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

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

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

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