php-Editor Xinyi kann beim Schreiben von Go-Skripten auf das Problem stoßen, dass ein Fehler nicht gefunden wurde, was dazu führt, dass das Skript nicht wie erwartet funktioniert. Dies ist eine weit verbreitete Obsession, die jedoch gelöst werden kann. In diesem Artikel werden einige mögliche Ursachen für dieses Problem vorgestellt und einige Lösungen bereitgestellt, die Ihnen helfen, dieses Problem einfacher zu lösen und dafür zu sorgen, dass das Go-Skript reibungslos funktioniert.
Ich versuche, dieses Leetcode-Problem zu lösen https://leetcode.com/problems/two-sum/ Aber aus irgendeinem Grund funktioniert es nicht und ich verstehe wirklich nicht, was falsch läuft. Es gibt lediglich [-1 -1] zurück, während [100 137] die korrekte Ausgabe ist.
package main import "fmt" func main() { arr := []int{10, 40, 1, 4, 100, 137} targetVal := 237 // twoSum(arr, targetVal) fmt.Println(twoSum(arr, targetVal)) } func twoSum(nums []int, target int) []int { starter := 0 // loop which is supposed to find first occurence of element that is less than target for i := 0; i < len(nums); i++ { if nums[i] < target { starter = i break } } // loop that iterates over remaining part of a slice (starting from nums[starter]) for i := starter; i < len(nums); i++ { if target-nums[starter] == nums[i] { return []int{nums[starter], nums[i]} } } return []int{-1, -1} }
Ich habe im Moment keine Debugging-Kenntnisse, also habe ich nur sichergestellt, dass nums[starter], nums[i] und alle Schleifen wie erwartet funktionierten. Ich habe fmt.println() verwendet, um ihre Werte zu protokollieren schien an der richtigen Stelle zu sein. Ich bin mir nicht sicher, was falsch ist
Das Problem mit Ihrem Code ist, dass er nie in das If gelangt
if target-nums[starter] == nums[i]
starter bleibt nach der ersten Schleife auf 0, da sie nur den ersten Wert speichert, der kleiner als der Zielwert ist.
Wenn Sie sich keine Sorgen um die Leistung machen, kann diese o(n²)-Funktion das richtige Ergebnis liefern:
func twoSum(nums []int, target int) []int { for i := 0; i < len(nums); i++ { for j := 0; j < len(nums); j++ { if nums[i]+nums[j] == target && i != j { return []int{j, i} } } } return []int{-1, -1} }
Das obige ist der detaillierte Inhalt vonFehler „Nicht gefunden', Go-Skript funktioniert nicht wie erwartet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!