주어진 문자열이 ABC의 하위 시퀀스로만 분할될 수 있는지 확인합니다.
문자열의 하위 시퀀스는 문자 순서를 변경하거나 새 문자열을 형성하지 않고 문자열의 모든 위치(0개 이상의 요소)에서 문자를 가져올 수 있는 문자열의 일부입니다. 이 문제에서는 문자열의 모든 문자가 'A', 'B' 또는 'C' 문자인 길이 N의 문자열이 제공됩니다. 우리의 임무는 문자열이 "ABC" 또는 "Not" 하위 시퀀스로만 분할될 수 있음을 찾는 것입니다. 문자열이 하위 시퀀스 "ABC"로만 분할된 경우 "yes"를 반환하고, 그렇지 않으면 "no"를 반환합니다.
으아아아지침 - 분할 방법은 다음과 같이 문자열을 "ABC"의 하위 시퀀스 2개로 분할하는 것입니다. -
가능한 방법 중 하나는 인덱스 0, 2, 3의 문자를 가져와서 하위 시퀀스 "ABC"를 형성한 다음, 인덱스 1, 4, 5의 문자를 가져와서 하위 시퀀스 "ABC"를 형성하는 것입니다.
또 다른 가능한 방법은 인덱스 0, 4, 5와 1, 2, 3의 문자를 가져와 하위 시퀀스 "ABC"를 형성하는 것입니다.
따라서 문자열은 "ABC"의 2개 하위 시퀀스로 분할될 수 있습니다.
으아아아설명 - 인덱스 5번에 나오는 'A'의 경우 그 뒤에 'B'가 없습니다. 따라서 전체 문자열을 고유한 하위 시퀀스 "ABC"로 분할할 수 없습니다. 그러므로 대답은 "아니요"입니다.
방법 1: 해시맵 사용
다음과 같이 두 가지 관찰 결과가 있습니다. -
문자열을 "ABC"로 분할해야 하고 문자 'A', 'B', 'C'의 개수가 같아야 하므로 문자열의 크기는 3으로 나누어야 합니다. 그렇지 않으면 조건을 충족할 수 없습니다.
문자 "A", "B" 및 "C"의 빈도를 계산할 때 'A'의 개수는 'B'의 개수보다 크거나 같아야 하며 'B'의 개수는 더 커야 합니다. 'C'의 개수와 같거나 같습니다. 왜냐하면 A의 개수 >= B의 개수 >= C의 cout
위의 관찰을 바탕으로 확인해야 할 세 가지 조건이 있습니다.
문자열 크기 % 3 == 0이어야 합니다.
A의 개수 >= B의 개수 >= C의 개수여야 합니다.
마지막 조건은 freq[ 'A' ] == freq[ 'B' ] == freq[ 'C' ] 여야 합니다.
주어진 문자열 "str"에 각 문자의 빈도를 저장해야 하므로 해시 맵을 사용하여 이 문제를 해결할 수 있습니다.
아래 방법을 단계별로 논의해 보겠습니다.
먼저, 주어진 문자열 "str"을 매개변수로 취하고 가능하면 원하는 문자열 "yes"를 반환하는 "checkSubsequences"라는 함수를 생성하고, 그렇지 않으면 "no"를 반환 값으로 반환합니다.
함수에서 모든 단계는 다음과 같습니다. -
문자열의 길이를 저장하는 변수 "len"을 만듭니다.
첫 번째 조건을 확인하고 길이가 3으로 나누어지지 않으면 'no'를 반환합니다.
'A', 'B', 'C' 문자의 빈도를 저장하는 해시 맵을 만듭니다. 따라서 공간복잡도는 일정하다.
-
for 루프를 사용하여 문자열을 0에서 len 미만까지 순회합니다.
문자열의 현재 문자 수 늘리기
-
두 번째 조건을 확인하고 "A"의 개수가 "B"의 개수보다 작거나 "B"의 개수가 "C"의 개수보다 작은 경우 "No"를 반환합니다.
li>
for 루프 후에 마지막 세 번째 조건을 확인하고 A의 개수가 B의 개수와 같지 않거나 B의 개수가 C의 개수와 같지 않으면 "No"를 반환해야 합니다.
마지막으로 모든 조건이 충족되면 "yes"를 반환합니다.
예
으아아아출력
으아아아시간과 공간의 복잡성
위 코드의 시간 복잡도는 문자열을 반복하기 때문에 O(N)입니다. 여기서 N은 문자열의 크기입니다.
위 코드의 공간 복잡도는 크기가 3인 숫자의 빈도를 저장하기 때문에 O(1)입니다.
결론
이 튜토리얼에서는 주어진 문자열을 하위 시퀀스 ABC로만 분할할 수 있는지 확인하는 프로그램을 구현했습니다. 빈도를 저장해야 했기 때문에 해싱 방법을 구현했습니다. 이 방법에서는 주로 세 가지 조건을 확인합니다. 모든 조건이 충족되면 문자열을 "ABC"의 하위 시퀀스로만 분할할 수 있음을 의미합니다.
위 내용은 주어진 문자열이 ABC의 하위 시퀀스로만 분할될 수 있는지 확인합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











실행되는 프로그램을 프로세스라고 합니다. 프로세스는 현재 운영 체제에서 실행되는 애플리케이션이거나 운영 체제와 관련된 애플리케이션일 수 있습니다. 응용 프로그램이 운영 체제에 연결되어 있으면 먼저 자체 실행 프로세스를 만듭니다. 다른 응용 프로그램은 실행을 위해 운영 체제 서비스에 의존합니다. 대부분의 응용 프로그램은 운영 체제, 소프트웨어 및 하드웨어를 유지 관리하는 운영 체제 서비스 및 백그라운드 응용 프로그램입니다. Python에는 애플리케이션이 열려 있는지 확인하는 다양한 방법이 있습니다. 하나씩 자세히 알아보겠습니다. psutil.process_iter() 함수 사용 psutil은 실행 중인 프로세스 및 시스템 활용도에 대한 정보를 검색할 수 있는 인터페이스를 사용자에게 제공하는 Python의 모듈입니다.

반복 가능한 객체는 루프나 반복 가능한 함수를 사용하여 모든 요소를 반복할 수 있는 객체입니다. 목록, 문자열, 사전, 튜플 등을 모두 반복 가능한 객체라고 합니다. Python 언어에는 객체가 반복 가능한지 여부를 확인하는 다양한 방법이 있습니다. 하나씩 살펴보겠습니다. 루프 사용하기 Python에는 두 가지 루프 기술이 있습니다. 하나는 "for" 루프를 사용하고 다른 하나는 "while" 루프를 사용하는 것입니다. 이 두 루프 중 하나를 사용하면 주어진 객체가 반복 가능한지 확인할 수 있습니다. 예제 이 예제에서는 "for" 루프를 사용하여 객체를 반복하고 반복되는지 여부를 확인합니다. 아래는 코드입니다. l=["사과",22,"오렌지색
![Teams에서 맞춤법 검사가 작동하지 않음 [수정됨]](https://img.php.cn/upload/article/000/887/227/170968741326618.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
때때로 Teams에서 맞춤법 검사가 작동하지 않는 경우가 있다는 사실을 알아차리기 시작했습니다. 맞춤법 검사는 효과적인 의사소통을 위한 필수 도구이며 이에 대한 공격은 작업 흐름에 상당한 혼란을 초래할 수 있습니다. 이 문서에서는 맞춤법 검사가 예상대로 작동하지 않는 일반적인 이유와 이전 상태로 복원하는 방법을 살펴보겠습니다. 따라서 Teams에서 맞춤법 검사가 작동하지 않는 경우 이 문서에 설명된 해결 방법을 따르세요. Microsoft 맞춤법 검사가 작동하지 않는 이유는 무엇입니까? Microsoft 맞춤법 검사가 제대로 작동하지 않는 데에는 여러 가지 이유가 있을 수 있습니다. 이러한 이유에는 호환되지 않는 언어 설정, 맞춤법 검사 기능 비활성화, MSTeam 또는 MSOffice 설치 손상 등이 포함됩니다. 또한 오래된 MSTeams 및 MSOf

Windows 11에서 SSD 상태를 확인하는 방법은 무엇입니까? 빠른 읽기, 쓰기 및 액세스 속도를 위해 SSD는 빠르게 HDD를 대체하고 있지만 SSD의 안정성이 더 뛰어나더라도 여전히 Windows 11에서 SSD의 상태를 확인해야 합니다. 그것을 운영하는 방법? 이 튜토리얼에서는 편집자가 방법을 공유합니다. 방법 1: WMIC1을 사용하고 Win+R 키 조합을 사용하여 wmic를 입력한 다음 확인을 누르거나 클릭합니다. Enter2. 이제 다음 명령을 입력하거나 붙여넣어 SSD 상태를 확인합니다. diskdrivegetstatus "상태: OK" 메시지가 나타나면 SSD 드라이브가 정상적으로 작동하고 있는 것입니다.

Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Golang으로 프로그래밍할 때 문자열이 특정 문자로 시작하는지 확인해야 하는 상황에 자주 직면하게 됩니다. 이 요구 사항을 충족하기 위해 Golang의 문자열 패키지에서 제공하는 기능을 사용할 수 있습니다. 다음에는 Golang을 사용하여 문자열이 특정 문자로 시작하는지 확인하는 방법을 구체적인 코드 예제와 함께 자세히 소개하겠습니다. Golang에서는 strings 패키지의 HasPrefix를 사용할 수 있습니다.

List 인터페이스의 contain() 메소드를 사용하여 목록에 객체가 존재하는지 확인할 수 있습니다. 포함() 메서드 booleancontains(Objecto) 이 목록에 지정된 요소가 포함되어 있으면 true를 반환합니다. 더 공식적으로는 이 목록에 (o==null?e==null:o.equals(e))와 같은 요소 e가 하나 이상 포함되어 있는 경우에만 true를 반환합니다. 매개변수 c - 이 목록에 존재하는지 테스트할 요소입니다. 반환 값 이 목록에 지정된 요소가 포함되어 있으면 true를 반환합니다. ClassCastException 발생 - 지정된 요소의 유형이 이 목록과 호환되지 않는 경우(선택 사항). 널P

윤년은 366일, 평년은 365일을 갖는 해가 윤년인지를 프로그램을 통해 확인하는 작업이다. 판단의 논리는 해당 연도가 400으로 나누어지는지, 4로 나누어지는지 여부를 확인하여 구현할 수 있지만, 이 두 숫자로 나누어지지 않으면 평년이 됩니다. 예Input-:year=2000Output-:2000isaLeapYearInput-:year=101Output-:101isnotaLeapyear 알고리즘StartStep1->declarefunctionbooltocheckifyearifaleapyearornotboolcheck(intye

다양한 회사의 자격 기준을 알아보려면 아래 표를 고려하십시오. CGPA의 중국어 번역은 다음과 같습니다. GPA 이상 8개 적격 회사 Google, Microsoft, Amazon, Dell, Intel, Wipro 7개 튜토리얼 포인트 이상, Accenture, Infosys , Emicon, Rellins 6rtCamp 이상, Cybertech, Skybags, Killer, Raymond 5Patronics 이상, Shoes, NoBrokers tpp 학생들의 면접 적격성을 확인하기 위해 Java 프로그램을 입력해 보겠습니다. 방법 1: ifelseif 조건 사용 일반적으로 여러 조건을 확인해야 할 때 사용합니다.
