Inhaltsverzeichnis
Methode 1: Hashmap verwenden
Beispiel
Ausgabe
Zeitliche und räumliche Komplexität
Fazit
Heim Backend-Entwicklung C++ Überprüft, ob die angegebene Zeichenfolge nur in Teilsequenzen von ABC aufgeteilt werden kann

Überprüft, ob die angegebene Zeichenfolge nur in Teilsequenzen von ABC aufgeteilt werden kann

Sep 06, 2023 pm 05:01 PM
检查 字符串拆分 Kinderordnung

Ü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
Nach dem Login kopieren

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
Nach dem Login kopieren

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“.

  • 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;
}
Nach dem Login kopieren

Ausgabe

no, the string is not splited only into the subsequences of ABC.
Nach dem Login kopieren

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!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Rechtschreibprüfung funktioniert in Teams nicht [Behoben] Rechtschreibprüfung funktioniert in Teams nicht [Behoben] Mar 06, 2024 am 09:10 AM

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

Wie überprüfe ich, ob die Anwendung in Python geöffnet ist? Wie überprüfe ich, ob die Anwendung in Python geöffnet ist? Aug 26, 2023 pm 06:49 PM

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.

Wie überprüfe ich, ob ein Objekt in Python iterierbar ist? Wie überprüfe ich, ob ein Objekt in Python iterierbar ist? Aug 25, 2023 pm 10:05 PM

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? So überprüfen Sie den SSD-Gesundheitsstatus unter Win11 Wie überprüfe ich den SSD-Gesundheitsstatus in Windows 11? So überprüfen Sie den SSD-Gesundheitsstatus unter Win11 Feb 14, 2024 pm 08:21 PM

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? Wie kann man in Golang überprüfen, ob eine Zeichenfolge mit einem bestimmten Zeichen beginnt? Mar 12, 2024 pm 09:42 PM

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

Wie überprüfe ich, ob ArrayList ein bestimmtes Element in Java enthält? Wie überprüfe ich, ob ArrayList ein bestimmtes Element in Java enthält? Sep 03, 2023 pm 04:09 PM

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

Java-Programm, mit dem überprüft wird, ob TPP-Studenten für Vorstellungsgespräche in Frage kommen Java-Programm, mit dem überprüft wird, ob TPP-Studenten für Vorstellungsgespräche in Frage kommen Sep 06, 2023 pm 10:33 PM

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

Schreiben Sie ein Programm in der Sprache C, um zu prüfen, ob ein bestimmtes Jahr ein Schaltjahr ist oder nicht Schreiben Sie ein Programm in der Sprache C, um zu prüfen, ob ein bestimmtes Jahr ein Schaltjahr ist oder nicht Sep 20, 2023 pm 03:33 PM

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-&gt;declarefunctionbooltocheckifyearifaleapyearornotboolcheck(intye

See all articles