


Überprüft, ob die angegebene Zeichenfolge nur in Teilsequenzen von ABC aufgeteilt werden kann
Eine Teilfolge einer Zeichenfolge ist ein Teil einer Zeichenfolge, in dem Zeichen von jeder Position (null oder mehr Elemente) der Zeichenfolge übernommen werden können, ohne die Reihenfolge der Zeichen zu ändern und eine neue Zeichenfolge zu bilden. In diesem Problem erhalten wir eine Zeichenfolge der Länge N, wobei jedes Zeichen der Zeichenfolge entweder ein „A“, „B“ oder „C“-Zeichen ist. Unsere Aufgabe besteht darin herauszufinden, dass die Zeichenfolge nur in die Teilsequenzen „ABC“ oder „Not“ aufgeteilt werden kann. Gibt „Ja“ zurück, wenn die Zeichenfolge nur in die Teilsequenz „ABC“ aufgeteilt ist, andernfalls wird „Nein“ zurückgegeben.
Input 1: str = “AABCBC” Output 1: yes
Anleitung – Die Aufteilungsmethode besteht darin, die Zeichenfolge wie folgt in zwei Teilsequenzen von „ABC“ aufzuteilen -
Eine der möglichen Methoden besteht darin, die Teilfolge „ABC“ zu bilden, indem man die Zeichen mit den Indizes 0, 2 und 3 nimmt, und dann die Teilfolge „ABC“ zu bilden, indem man die Zeichen mit den Indizes 1, 4 und 5 nimmt.
Eine andere Möglichkeit besteht darin, die Teilsequenz „ABC“ zu bilden, indem die Zeichen an den Indizes 0, 4, 5 und 1, 2, 3 abgerufen werden.
Somit kann die Zeichenfolge in zwei Teilsequenzen von „ABC“ aufgeteilt werden.
Input 2: str = “AABBBACCC” Output 2: no
Erklärung – Für „A“, das bei Indexnummer 5 auftritt, gibt es kein „B“ danach. Daher kann die gesamte Zeichenfolge nicht in eindeutige Teilsequenzen „ABC“ aufgeteilt werden. Daher lautet die Antwort „Nein“.
Methode 1: Hashmap verwenden
Wir haben folgende zwei Beobachtungen -
Die Größe der Zeichenfolge sollte durch 3 teilbar sein, da wir die Zeichenfolge in „ABC“ aufteilen müssen und die Anzahl der Zeichen „A“, „B“ und „C“ gleich sein sollte. Andernfalls können wir die Bedingungen nicht erfüllen.
Wenn wir die Häufigkeiten der Zeichen „A“, „B“ und „C“ zählen, muss die Anzahl von „A“ größer oder gleich der Anzahl von „B“ und die Anzahl von „B“ sein größer oder gleich der Anzahl von „C“. Weil die Anzahl von A >= die Anzahl von B >= die Anzahl von C ist
Basierend auf den obigen Beobachtungen müssen wir drei Bedingungen überprüfen.
sollte die Zeichenfolgengröße % 3 == 0 haben.
sollte A-Zählung >= B-Zählung >= C-Zählung sein.
Die letzte Bedingung sollte freq[ ‚A‘ ] == freq[ ‚B‘ ] == freq[ ‚C‘ ] sein.
Wir können eine Hash-Map verwenden, um dieses Problem zu lösen, da wir die Häufigkeit jedes Zeichens in der angegebenen Zeichenfolge „str“ speichern müssen.
Lassen Sie uns die folgende Methode Schritt für Schritt besprechen –
Zuerst erstellen wir eine Funktion namens „checkSubsequences“, die die angegebene Zeichenfolge „str“ als Parameter verwendet und nach Möglichkeit die erforderliche Zeichenfolge „yes“ zurückgibt, andernfalls wird „no“ als Rückgabewert zurückgegeben.
In der Funktion sind alle Schritte unten angegeben -
Erstellen Sie die Variable „len“, um die Länge der Zeichenfolge zu speichern.
Überprüfen Sie die erste Bedingung und geben Sie „Nein“ zurück, wenn die Länge nicht durch 3 teilbar ist.
Erstellen Sie eine Hash-Map, um die Häufigkeiten der Zeichen „A“, „B“ und „C“ zu speichern. Daher ist die Raumkomplexität konstant.
Verwenden Sie eine for-Schleife, um die Zeichenfolge von 0 auf weniger als len zu durchlaufen.
Erhöhen Sie die aktuelle Zeichenanzahl der Zeichenfolge
Überprüfen Sie die zweite Bedingung und geben Sie „Nein“ zurück, wenn die Anzahl von „A“ kleiner ist als die Zahl von „B“ oder die Zahl von „B“ kleiner ist als die Zahl von „C“.
li>
Nach der for-Schleife müssen wir die letzte dritte Bedingung überprüfen und „Nein“ zurückgeben, wenn die Anzahl von A nicht mit der Anzahl von B übereinstimmt oder die Anzahl von B nicht mit der Anzahl von C übereinstimmt.
Wenn schließlich alle Bedingungen erfüllt sind, geben Sie „Ja“ zurück.
Beispiel
#include <bits/stdc++.h> using namespace std; // function to check subsequences of "ABC" string checkSubsequences( string str ){ int len = str.size(); //getting length of the string str // check first condition if( len%3 != 0 ) { return "no"; } map< char, int >freq; //store the count of character 'A', 'B' and 'C' for( int i=0; i<len; i++){ freq[ str[i] ]++; // increase the count of the character //chech second condition if(freq[ 'A' ] < freq[ 'B' ] || freq[ 'B' ] < freq[ 'C' ]){ return "no"; } } //check third condition if(freq[ 'A' ] != freq[ 'B' ] || freq[ 'B' ] != freq[ 'C' ]){ return "no"; } // it is possible to split string only into subsequences of "ABC" return "yes"; } // main function int main(){ string str = "ABAAABCBC";// given string // calling the function 'checkSubsequences' to check is it possible to split // string into subsequences of "ABC" string result = checkSubsequences( str ); if( result == "yes" ){ cout<< result << ", the string is splited only into the subsequences of ABC"; } else { cout<< result << ", the string is not splited only into the subsequences of ABC."; } return 0; }
Ausgabe
no, the string is not splited only into the subsequences of ABC.
Zeitliche und räumliche Komplexität
Die zeitliche Komplexität des obigen Codes beträgt O(N), da wir über die Zeichenfolge iterieren. wobei N die Größe der Zeichenfolge ist.
Die räumliche Komplexität des obigen Codes beträgt O(1), da wir die Häufigkeit der Zahl speichern, deren Größe konstant 3 ist.
Fazit
In diesem Tutorial haben wir ein Programm implementiert, um zu prüfen, ob eine bestimmte Zeichenfolge nur in die Teilsequenzen ABC aufgeteilt werden kann. Wir haben eine Hashing-Methode implementiert, weil wir die Häufigkeiten speichern mussten. Bei dieser Methode prüfen wir hauptsächlich drei Bedingungen. Wenn alle Bedingungen erfüllt sind, bedeutet dies, dass wir die Zeichenfolge nur in Teilsequenzen von „ABC“ aufteilen können.
Das obige ist der detaillierte Inhalt vonÜberprüft, ob die angegebene Zeichenfolge nur in Teilsequenzen von ABC aufgeteilt werden kann. 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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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


![Rechtschreibprüfung funktioniert in Teams nicht [Behoben]](https://img.php.cn/upload/article/000/887/227/170968741326618.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Uns ist aufgefallen, dass die Rechtschreibprüfung für Teams manchmal nicht mehr funktioniert. Die Rechtschreibprüfung ist ein wesentliches Werkzeug für eine effektive Kommunikation, und jeder Angriff darauf kann zu erheblichen Störungen des Arbeitsablaufs führen. In diesem Artikel untersuchen wir häufige Gründe, warum die Rechtschreibprüfung möglicherweise nicht wie erwartet funktioniert, und wie Sie sie in den vorherigen Zustand zurückversetzen können. Wenn die Rechtschreibprüfung in Teams nicht funktioniert, befolgen Sie die in diesem Artikel genannten Lösungen. Warum funktioniert die Rechtschreibprüfung von Microsoft nicht? Es kann mehrere Gründe dafür geben, dass die Rechtschreibprüfung von Microsoft nicht ordnungsgemäß funktioniert. Zu diesen Gründen gehören inkompatible Spracheinstellungen, deaktivierte Rechtschreibprüfung, beschädigte MSTeam- oder MSOffice-Installation usw. Außerdem veraltete MSTeams und MSOf

Das ausgeführte Programm wird als Prozess bezeichnet. Ein Prozess kann eine Anwendung sein, die auf dem aktuellen Betriebssystem ausgeführt wird, oder eine Anwendung, die mit dem Betriebssystem zusammenhängt. Wenn eine Anwendung an das Betriebssystem gebunden ist, erstellt sie zunächst einen Prozess, um sich selbst auszuführen. Andere Anwendungen sind zur Ausführung auf Betriebssystemdienste angewiesen. Bei den meisten Anwendungen handelt es sich um Betriebssystemdienste und Hintergrundanwendungen, die das Betriebssystem, die Software und die Hardware warten. In Python gibt es verschiedene Methoden, um zu überprüfen, ob die Anwendung geöffnet ist oder nicht. Lassen Sie uns sie einzeln im Detail kennenlernen. Verwenden der Funktion psutil.process_iter() psutil ist ein Modul in Python, das Benutzern eine Schnittstelle zum Abrufen von Informationen über laufende Prozesse und Systemauslastung bietet.

Ein iterierbares Objekt ist ein Objekt, über dessen alle Elemente mithilfe einer Schleife oder einer iterierbaren Funktion iteriert werden kann. Listen, Zeichenfolgen, Wörterbücher, Tupel usw. werden alle als iterierbare Objekte bezeichnet. In der Python-Sprache gibt es verschiedene Möglichkeiten zu überprüfen, ob ein Objekt iterierbar ist. Schauen wir uns das einzeln an. Verwenden von Schleifen In Python gibt es zwei Schleifentechniken: Eine verwendet die „for“-Schleife und die andere die „while“-Schleife. Mithilfe einer dieser beiden Schleifen können wir prüfen, ob ein bestimmtes Objekt iterierbar ist. Beispiel In diesem Beispiel versuchen wir, ein Objekt mithilfe einer „for“-Schleife zu iterieren und prüfen, ob es iteriert wird oder nicht. Unten ist der Code. l=["apple",22,"orang

Wie überprüfe ich den SSD-Gesundheitsstatus in Windows 11? Aufgrund ihrer hohen Lese-, Schreib- und Zugriffsgeschwindigkeit ersetzen SSDs schnell Festplatten. Obwohl sie zuverlässiger sind, müssen Sie dennoch den Zustand Ihrer SSDs in Windows 11 überprüfen. Wie bedient man es? In diesem Tutorial stellt Ihnen der Herausgeber die Methode vor. Methode 1: Verwenden Sie WMIC1, verwenden Sie die Tastenkombination Win+R, geben Sie wmic ein und drücken oder klicken Sie dann auf OK. Geben Sie 2 ein. Geben Sie nun den folgenden Befehl ein oder fügen Sie ihn ein, um den SSD-Gesundheitsstatus zu überprüfen: diskdrivegetstatus Wenn Sie die Meldung „Status: OK“ erhalten, funktioniert Ihr SSD-Laufwerk normal.

Wie kann man in Golang überprüfen, ob eine Zeichenfolge mit einem bestimmten Zeichen beginnt? Beim Programmieren in Golang kommt es häufig vor, dass Sie prüfen müssen, ob eine Zeichenfolge mit einem bestimmten Zeichen beginnt. Um diese Anforderung zu erfüllen, können wir die vom Strings-Paket in Golang bereitgestellten Funktionen verwenden, um dies zu erreichen. Als Nächstes stellen wir anhand spezifischer Codebeispiele ausführlich vor, wie Sie mit Golang überprüfen können, ob eine Zeichenfolge mit einem bestimmten Zeichen beginnt. In Golang können wir HasPrefix aus dem Strings-Paket verwenden

Mit der Methode „contains()“ der Schnittstelle „List“ können Sie prüfen, ob ein Objekt in der Liste vorhanden ist. enthält()-Methode booleancontains(Objecto) Gibt „true“ zurück, wenn diese Liste das angegebene Element enthält. Formeller ausgedrückt: Gibt genau dann „true“ zurück, wenn diese Liste mindestens ein Element e enthält, sodass (o==null?e==null:o.equals(e)). Parameter c – das Element, dessen Anwesenheit in dieser Liste getestet werden soll. Rückgabewert Gibt „true“ zurück, wenn diese Liste das angegebene Element enthält. Löst eine ClassCastException aus – wenn der Typ des angegebenen Elements mit dieser Liste nicht kompatibel ist (optional). NullP

Bitte beachten Sie die folgende Tabelle, um die Zulassungskriterien für verschiedene Unternehmen zu kennen. Die chinesische Übersetzung von CGPA lautet: GPA größer oder gleich 8 berechtigte Unternehmen Google, Microsoft, Amazon, Dell, Intel, Wipro größer oder gleich 7 Tutorial-Punkte, Accenture , Infosys, Emicon, Rellins größer oder gleich 6rtCamp, Cybertech, Skybags, Killer, Raymond größer oder gleich 5Patronics, Shoes, NoBrokers Lassen Sie uns das Java-Programm aufrufen, um die Eignung von tpp-Studenten für ein Vorstellungsgespräch zu überprüfen. Methode 1: Verwenden der ifelseif-Bedingung Normalerweise verwenden wir, wenn wir mehrere Bedingungen überprüfen müssen

Ein Schaltjahr hat 366 Tage, während ein gewöhnliches Jahr 365 Tage hat. Die Aufgabe besteht darin, durch ein Programm zu überprüfen, ob ein bestimmtes Jahr ein Schaltjahr ist. Die Urteilslogik kann umgesetzt werden, indem geprüft wird, ob das Jahr durch 400 oder 4 teilbar ist. Wenn es jedoch nicht durch diese beiden Zahlen teilbar ist, handelt es sich um ein gewöhnliches Jahr. BeispielInput-:year=2000Output-:2000isaLeapYearInput-:year=101Output-:101isnotaLeapyear-AlgorithmusStartStep1->declarefunctionbooltocheckifyearifaleapyearornotboolcheck(intye
