


Verbesserung der Eingabescangeschwindigkeit für eine schnellere Programmausführung
Problembeschreibung
Der angegebene Code versucht um ein SPOJ-Problem zu lösen, indem man eine Liste von Zahlen durchläuft und ermittelt, ob jede Zahl durch eine Konstante k teilbar ist. Allerdings tritt bei der Ausführung eine Zeitüberschreitung auf, da das Scannen der Eingaben als langsam empfunden wird.
Lösung
Verwendung von bufio.Scanner
Zur Verbesserung Um die Effizienz des Eingabescannens zu verbessern, können wir den bufio.Scanner nutzen, der auf die schnelle zeilenweise Eingabeverarbeitung zugeschnitten ist. Anstelle des standardmäßigen fmt.Scan verwenden wir bufio.Scanner, um Eingabezeilen abzurufen.
Zahlenkonvertierung optimieren
Zur verbesserten Zahlenkonvertierung führen wir toInt() ein Funktion, die Zahlen direkt aus rohen Eingabebytes extrahiert. Dies vermeidet die langsamere Konvertierungsmethode von Scanner.Text() und eliminiert unnötige String-Erstellung.
toInt() erreicht dies, indem es die Eingabebytes durchläuft und das Ergebnis schrittweise mit 10 multipliziert. Die Bytes entsprechen dem UTF- 8 codierte Folge der Dezimaldarstellung der Zahl.
Code Snippet
Das überarbeitete Code-Snippet unten enthält die folgenden Optimierungen:
package main import ( "bufio" "fmt" "os" ) func main() { var n, k, c int scanner := bufio.NewScanner(os.Stdin) scanner.Scan() fmt.Sscanf(scanner.Text(), "%d %d", &n, &k) for ;n > 0; n-- { scanner.Scan() if toInt(scanner.Bytes())%k == 0 { c++ } } fmt.Println(c) } func toInt(buf []byte) (n int) { for _, v := range buf { n = n*10 + int(v-'0') } return }
Zusätzliche Hinweise
Diese optimierte Lösung zeigt eine deutliche Verbesserung in Ausführungsgeschwindigkeit im Vergleich zu früheren Methoden. Es wird eine gültige Eingabe vorausgesetzt, einschließlich des Vorhandenseins von n Zeilen nach der ersten Eingabe.
Für Szenarien mit geschlossenen Eingaben kann eine vereinfachte for-Schleife verwendet werden:
for scanner.Scan() { if toInt(scanner.Bytes())%k == 0 { c++ } }
Das obige ist der detaillierte Inhalt vonWie kann bufio.Scanner und optimierte Nummernkonvertierung das Scannen von Eingaben in Go-Programmen beschleunigen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Sie sollten sich um das "Zeichenfolgen" -Paket in Go kümmern, da es Tools zum Umgang mit Textdaten und dem Spleißen von grundlegenden Zeichenfolgen bis hin zu erweiterten regulären Ausdrucksanpassungen bietet. 1) Das "Zeichenfolgen" -Paket bietet effiziente String -Operationen, z. B. Join -Funktionen, die zum Spleißen von Zeichenfolgen verwendet werden, um Leistungsprobleme zu vermeiden. 2) Es enthält erweiterte Funktionen, wie z. B. die entsprechende Funktion, um zu überprüfen, ob eine Zeichenfolge einen bestimmten Zeichensatz enthält. 3) Die Ersatzfunktion wird verwendet, um Substrings in einer Zeichenfolge zu ersetzen, und die Aufmerksamkeit sollte auf die Ersatzauftrag und die Fallempfindlichkeit geschenkt werden. 4) Die Split -Funktion kann Zeichenfolgen entsprechend dem Trennzeichen teilen und wird häufig für die regelmäßige Expressionsverarbeitung verwendet. 5) Die Leistung muss bei der Verwendung berücksichtigt werden, wie z.

Das "Coding/Binary" PackageingoSential ForHandlingBinaryData, das die Bills-Forreading und WritingBinaryDataEffictionly anbietet

Das Beherrschen des Bytes -Pakets in Go kann dazu beitragen, die Effizienz und Eleganz Ihres Codes zu verbessern. 1) Das Bytes -Paket ist entscheidend für die Analyse binärer Daten, Verarbeitungsnetzwerkprotokolle und Speicherverwaltung. 2) Bytes verwenden. 3) Das Bytes -Paket bietet die Funktionen des Suchens, Ersetzens und Segmentierens von Bytescheiben. 4) Der Typ Bytes.reader eignet sich zum Lesen von Daten aus Bytescheiben, insbesondere in E/A -Operationen. 5) Das Bytes -Paket arbeitet in Zusammenarbeit mit Go's Müllsammler zusammen und verbessert die Effizienz der Big -Data -Verarbeitung.

Sie können das "Saiten" -Paket verwenden, um Saiten zu manipulieren. 1) Verwenden Sie Strings.trimspace, um Whitespace -Zeichen an beiden Enden der Zeichenfolge zu entfernen. 2) Verwenden Sie Strings. 3) Fucken Sie die Stringschnitte in eine Zeichenfolge durch Strings.join. 4) Verwenden Sie Strings.Contains, um zu überprüfen, ob die Zeichenfolge ein bestimmtes Substring enthält. 5) Verwenden Sie Strings.replaceall, um den globalen Ersatz durchzuführen. Achten Sie bei der Verwendung auf Leistung und potenzielle Fallstricke.

ThytespackageingoishighryeffectiveforByteslicemanipulation, AngebotsfunktionenForssearching, Spalten, Beiträge und Buffern.1) useBytes.ContainSearchForByTeSequences.2) Bytes.SsplithelpreakdownByTeslicesuseusedelimiter.3) durchtes

Thealternativestogo'SByTeSpackageIncludethestringspackage, bufiopackage und CustomStructs.1) thestringeSpackageCanBeUTForByTemanipulationByConvertingByTestOstoStoStackback.2) theBufiPackageIssidealForHandlinglargestreamStreamStreamStreamStreamStreamStreamStreamsEdTeffictionly

Die "Bytes" PackageingoSessentialFoictumingLyManipulationsByteslices, Crucial ForBinaryData, NetworkProtocols und Fileei/O.itoffersfunctions LikeIneIntexForsarching, pufferforhandlinglargedatasets, LeserforsimulatingStreamReAding und Joinseffizienz

Go'sStringSpackageScrucialForFicientStringManipulation, Offeringtoolslikestrings.Split (), Strings.join (), Strings.Replaceall (), und Strings.Contains (). 1) Strings


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

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver Mac
Visuelle Webentwicklungstools

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.

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

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