Lintcode-Fragedatensatz 3
Ausdruck erweitern Wortumbruch II Partition Equal Subset Sum
String-Erweiterungsproblem, entsprechend der Zahl vor [] erweitern Zeichenfolgen verwalten hauptsächlich zwei Stapel, einer dient zum Erweitern des Zahlenstapels und der andere zum Erweitern des Inhaltsstapels mehr als eine Ziffer, und der Rest spielt keine Rolle
class Solution:# @param {string} s an expression includes numbers, letters and brackets# @return {string} a stringdef expressionExpand(self, s):# Write your code herenl=[] sl=[] sc=''res=''lstr=''for i in s:if i.isdigit():if not lstr.isdigit(): sl.append(sc) sc=''sc = sc + ielse:if i=='[': nl.append(int(sc)) sc = ''sl.append('[')elif i==']': n=nl.pop()while len(sl)>0: k=sl.pop()if k== '[':breaksc = k+ sc ts=''for j in range(n):ts= ts + sc sc=''if len(nl) > 0:sl.append(ts)else: res = res + tselse:if len(nl)>0: sc = sc + ielse: res = res + i lstr=ireturn res
Wortumbruch II
Wortumbruchproblem, Suche vom Anfang der Zeichenfolge im Array an, Fügen Sie es dem Stapel hinzu, wenn es gefunden wird, und führen Sie dann jedes Mal eine Schleife aus. Bestimmen Sie, ob die gepoppte Zeichenfolge vollständig ist, fügen Sie das Ergebnis hinzu, wenn es vollständig ist, und suchen Sie nach dem Follow-up, wenn es unvollständig ist. Fügen Sie es dem Stapel hinzu, ohne mit dem nächsten Zyklus fortzufahren. Hier muss eine Mehrdeutigkeit bestehen. Kann die Zeichenfolge in WordDict wiederverwendet werden?
Dieses Ding wird sehr langsam sein, wenn die Zeichenfolge sehr lang ist und sich viele Wörterbucharrays dahinter befinden. Derzeit scheint es keine solche Situation zu geben Von Lintcode bereitgestellte Testdaten gibt es nur in einem Sonderfall. Nach dem Hinzufügen eines Filters ist zu beachten, dass die Startwith-Funktion
immer True zurückgibt, was der Fall ist ein bisschen nervig...
class Solution:# @param {string} s a string# @param {set[str]} wordDict a set of wordsdef wordBreak(self, s, wordDict):# Write your code herehead=[] ss=''for i in s:if ss=='': ss=ielse:if i not in ss: ss = ss + ifor i in ss: flag=Falsefor di in wordDict:if i in di: flag=Truebreak;if not flag:return []for di in wordDict:if di !='' and s.startswith(di): head.append(di)if len(head)<1:return [] cur=s res=[]while len(head)>0: h=head.pop() le=len(h.replace(' ','')) cur=s[le:]if cur == '': res.append(h)continuefor di in wordDict:if cur.startswith(di): head.append(h+' '+di) return res
Partition Equal Subset Sum
Array-Gruppen-Summationsproblem In der Frage heißt es, dass die Bedingungen darin bestehen, dass viele Zahlen ganze Zahlen sind und 100 nicht überschreiten und die Array-Länge 200 nicht überschreitet. Verwenden Sie dazu einfach dynamische Programmierung, was eine vereinfachte Version des Rucksackproblems ist. Finden Sie zuerst die Summe von Wenn es sich um eine gerade Zahl handelt, kann sie in zwei Gruppen unterteilt werden. Andernfalls wird die endgültige Summe der Gruppen durch 2 ermittelt Das Problem besteht darin, dass die Zahlen im Array den Dingen ähneln, die in den Rucksack gesteckt werden müssen. Anders als beim Rucksackproblem ist es erforderlich, dass der Rasterwert gleich ist Diese Summe muss nicht bis zum Ende durchlaufen werden. Ein Gitter
class Solution:# @param {int[]} nums a non-empty array only positive integers# @return {boolean} return true if can partition or falsedef canPartition(self, nums):# Write your code heresum=0for n in nums: sum = sum +nif sum%2!=0:return False k=sum//2a=[None]*len(nums)for i in range(len(nums)): a[i]=[0]*k for i in range(len(nums)):for j in range(k):if i == 0: a[i][j] = nums[i] if nums[i] < j+1 else 0else:if nums[i]> j+1: a[i][j]=a[i-1][j]else: a[i][j]=max(nums[i]+a[i-1][j+1-nums[i]],a[i-1][j]) if a[i][j] ==k:return Truereturn False
Das obige ist der detaillierte Inhalt vonLintcode-Fragedatensatz 3. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

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

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Die Pinduoduo-Software bietet viele gute Produkte, die Sie jederzeit und überall kaufen können. Die Qualität jedes Produkts wird streng kontrolliert, jedes Produkt ist echt und es gibt viele Vorzugsrabatte beim Einkaufen, sodass jeder online einkaufen kann. Ich kann einfach nicht aufhören. Geben Sie Ihre Mobiltelefonnummer ein, um sich online anzumelden, fügen Sie online mehrere Lieferadressen und Kontaktinformationen hinzu und prüfen Sie jederzeit die neuesten Logistiktrends. Suchen Sie nach oben und unten, um zu kaufen und eine Bestellung aufzugeben. Sie können den Komfort genießen, ohne das Haus zu verlassen. Mit dem Online-Einkaufsservice können Sie auch alle Einkaufsunterlagen, einschließlich der von Ihnen gekauften Waren, einsehen und erhalten Dutzende von roten Einkaufsumschlägen und Gutscheinen kostenlos Detaillierte Online-Methode zum Anzeigen gekaufter Produktdatensätze. 1. Öffnen Sie Ihr Telefon und klicken Sie auf das Pinduoduo-Symbol.

Die Anrufaufzeichnung im iPhone wird oft unterschätzt und ist eine der wichtigsten Funktionen des iPhone. Aufgrund ihrer Einfachheit ist diese Funktion von entscheidender Bedeutung und kann wichtige Erkenntnisse über die auf dem Gerät getätigten oder empfangenen Anrufe liefern. Ob für Arbeitszwecke oder für Gerichtsverfahren, die Möglichkeit, auf Anrufaufzeichnungen zuzugreifen, kann von unschätzbarem Wert sein. Vereinfacht ausgedrückt bezieht sich der Anrufverlauf auf die Einträge, die auf Ihrem iPhone erstellt werden, wenn Sie einen Anruf tätigen oder entgegennehmen. Diese Protokolle enthalten wichtige Informationen, einschließlich des Namens des Kontakts (oder der Nummer, falls nicht als Kontakt gespeichert), Zeitstempel, Dauer und Anrufstatus (gewählt, verpasst oder nicht angenommen). Sie sind eine prägnante Aufzeichnung Ihres Kommunikationsverlaufs. Der Anrufverlauf umfasst auf Ihrem iPhone gespeicherte Anrufverlaufsstreifen

So zeigen Sie den Befehlsverlauf unter Linux an: Unter Linux verwenden wir den Befehl „history“, um die Liste aller zuvor ausgeführten Befehle anzuzeigen. Die Syntax ist sehr einfach: „history“ Zu den Optionen für die Kopplung mit dem Befehl „history“ gehören: Optionsbeschreibung –c löscht den Befehlsverlauf für die aktuelle Sitzung –w schreibt den Befehlsverlauf in eine Datei –r lädt den Befehlsverlauf aus der Verlaufsdatei neu – n Begrenzen Sie die Anzahl der Ausgaben der letzten Befehle. Führen Sie einfach den Befehl „history“ aus, um eine Liste aller zuvor ausgeführten Befehle in einem Linux-Terminal anzuzeigen: Zusätzlich zur Anzeige des Befehlsverlaufs können Sie auch den Befehlsverlauf verwalten und Änderungen an zuvor ausgeführten Befehlen vornehmen, rückgängig machen Durchsuchen Sie den Befehlsverlauf oder löschen Sie den Verlauf sogar vollständig

Mit dem iPhone können Sie Medikamente zur Gesundheits-App hinzufügen, um die Medikamente, Vitamine und Nahrungsergänzungsmittel, die Sie täglich einnehmen, zu verfolgen und zu verwalten. Anschließend können Sie eingenommene oder ausgelassene Medikamente protokollieren, wenn Sie eine Benachrichtigung auf Ihrem Gerät erhalten. Nachdem Sie Ihre Medikamente protokolliert haben, können Sie sehen, wie oft Sie sie eingenommen oder ausgelassen haben, um Ihren Gesundheitszustand besser im Auge zu behalten. In diesem Beitrag zeigen wir Ihnen, wie Sie den Protokollverlauf ausgewählter Medikamente in der Health-App auf dem iPhone anzeigen. Eine kurze Anleitung zum Anzeigen Ihres Medikamentenprotokollverlaufs in der Gesundheits-App: Gehen Sie zu Gesundheits-App>Durchsuchen>Medikamente>Medikamente>Medikament auswählen>Optionen&a

C#-Entwicklungsvorschläge: Protokollierungs- und Überwachungssystem Zusammenfassung: Im Softwareentwicklungsprozess sind Protokollierungs- und Überwachungssysteme entscheidende Werkzeuge. In diesem Artikel werden die Rolle und Implementierungsvorschläge von Protokollierungs- und Überwachungssystemen in der C#-Entwicklung vorgestellt. Einleitung: Protokollierung und Überwachung sind wesentliche Werkzeuge in großen Softwareentwicklungsprojekten. Sie können uns helfen, den laufenden Status des Programms in Echtzeit zu verstehen und Probleme schnell zu erkennen und zu lösen. In diesem Artikel wird erläutert, wie Protokollierungs- und Überwachungssysteme in der C#-Entwicklung verwendet werden, um die Softwarequalität und Entwicklungseffizienz zu verbessern. Die Rolle des Protokollierungssystems

So protokollieren und überwachen Sie Java-Entwicklungsprojekte 1. Einführung in den Hintergrund Mit der rasanten Entwicklung des Internets haben immer mehr Unternehmen damit begonnen, Java zu entwickeln und verschiedene Arten von Anwendungen zu erstellen. Im Entwicklungsprozess sind Protokollierung und Überwachung ein wichtiges Bindeglied, das nicht ignoriert werden darf. Durch Protokollierung und Überwachung können Entwickler Probleme rechtzeitig erkennen und lösen, um die Stabilität und Sicherheit von Anwendungen zu gewährleisten. 2. Die Bedeutung der Protokollierung 1. Problemverfolgung: Wenn ein Anwendungsfehler auftritt, kann die Protokollierung uns dabei helfen, das Problem schnell zu lokalisieren.

Wie lösche ich den iPhone-Verlauf in Safari? Um Ihren Browser- und Suchverlauf in Apples Safari zu löschen, müssen Sie die App „Einstellungen“ auf Ihrem Gerät öffnen. Nachdem Sie „Einstellungen“ ausgewählt haben, müssen Sie nach unten scrollen und „Safari“ auswählen. Dann erscheint ein weiteres Menü und Sie müssen „Verlauf und Website-Daten löschen“ auswählen. Sie müssen nun „Verlauf und Daten löschen“ aus dem Menü auswählen, wodurch der gesamte Suchverlauf, Browserverlauf, Cookies und Daten aus Apples Safari-Browser gelöscht werden. Das war's, Ihr gesamter bisheriger Browser- und Suchverlauf wird jetzt aus Safari gelöscht. Wenn Sie nicht den gesamten Suchverlauf in Safari löschen möchten

Wir alle wissen, dass es sich bei den oben genannten Programmen um sehr gute Sportarten handelt, mit denen Benutzer verschiedene Sportarten in Echtzeit absolvieren können, und wir können auch einige der oben genannten Flugbahnen während einiger Laufprozesse sehen Benutzer kennen einige der oben genannten Funktionsinformationen nicht, daher werde ich Ihnen heute einige der Inhalte und Erfahrungen gut erklären, damit jeder verschiedene Funktionen besser ausführen kann Tracks und Aufzeichnungen über Ihr eigenes Laufen, verpassen Sie es nicht. Weitere hochwertige Inhalte warten auf Sie. Wenn Sie es auch wissen möchten Schauen Sie sich jetzt den Editor an.
