백엔드 개발 C++ 주어진 문장에서 부분 문자열 S2가 발생한 후에 부분 문자열 S1이 나타나는지 확인합니다.

주어진 문장에서 부분 문자열 S2가 발생한 후에 부분 문자열 S1이 나타나는지 확인합니다.

Aug 26, 2023 am 11:13 AM
조사하다 주어진 문장 하위 문자열 나타나다

주어진 문장에서 부분 문자열 S2가 발생한 후에 부분 문자열 S1이 나타나는지 확인합니다.

이 문제에서는 주어진 문자열 S에서 하위 문자열 S2가 발생한 후에 하위 문자열 S1이 발생하는지 확인해야 합니다. 문자열 S에서 S1과 S2의 시작 인덱스를 비교하여 이 문제를 해결할 수 있습니다. p>

문제 설명 - S, S1, S2라는 세 개의 하위 문자열이 제공됩니다. 문자열 S에는 항상 S1이 하위 문자열로 포함됩니다. 주어진 문자열 S에서 부분 문자열 S1이 부분 문자열 S2 뒤에 나타나는지 확인해야 합니다.

Enter – S = “abxtutorialspointwelcomepoint”, S1 = “환영합니다”, S2 = “포인트”

Output – 예

설명 – 문자열 S에서 "점" 하위 문자열이 2번 나타납니다. 하나는 "환영합니다" 앞에 있고 다른 하나는 "환영합니다" 뒤에 있습니다. 따라서 문자열 S2가 발생한 후에 문자열 S1이 발생한다고 말할 수 있습니다.

Input– S = "abcdefgh", S1 = "abcd", S2 = "gh";

Output – 아니요

설명S1은 문자열 S의 시작 부분에 있습니다. 따라서 S1은 하위 문자열 S2 뒤에 나타나지 않습니다.

Enter – S = “abce”, S1 = “bc”, S2 = “xy”

Output – 아니요

Explanation – 문자열 S에는 문자열 S2가 존재하지 않으므로 No.를 인쇄합니다.

방법 1

이 방법에서는 S2 하위 문자열의 모든 시작 인덱스를 찾아 컬렉션에 저장합니다. 그 후 S1의 시작 인덱스를 얻습니다. S2의 각 시작 인덱스를 S1의 시작 인덱스와 비교하고 집합의 값이 S2의 시작 인덱스보다 작은 경우 하위 문자열 S1이 하위 문자열 S2가 발생한 후에 발생한다고 말할 수 있습니다.

알고리즘

  • 부분 문자열 S2의 시작 인덱스를 저장하는 컬렉션을 정의합니다.

  • find() 메서드를 사용하여 S2 하위 문자열의 첫 번째 시작 인덱스를 찾습니다.

  • while 루프를 사용하여 하위 문자열 S2의 모든 시작 인덱스를 가져오고 insert() 메서드를 사용하여 컬렉션에 저장합니다.

  • 설정된 값을 순회합니다. 주어진 문자열 S에서 하위 문자열 S1의 시작 인덱스보다 작은 값이 있으면 true를 반환합니다.

  • 마지막으로 false를 반환합니다.

으아악

출력

으아악

시간 복잡도 - O(N*K), 문자열 S2의 시작 인덱스를 찾아야 하기 때문입니다.

공간 복잡도 - 문자열 S2의 시작 인덱스를 저장하므로 O(N)입니다.

방법 2

이 방법에서는 문자열을 반복합니다. 문자열 S에는 항상 문자열 S1이 포함되어 있으므로 S2가 S1보다 먼저 발생하는 경우 true를 반환합니다.

알고리즘

  • 변수의 길이를 저장하려면 len, n1 및 n2 변수를 정의하세요.

  • 문자열 탐색을 시작하세요.

  • 'temp 문자열을 정의하고 i번째 인덱스에서 시작하여 길이가 n2인 하위 문자열로 초기화합니다.

  • temp == S2이면 true를 반환합니다.

  • i번째 인덱스부터 길이가 n1인 하위 문자열을 가져옵니다. temp == s1이면 false를 반환합니다.

  • 마침내 true를 반환합니다.

으아악

출력

으아악

시간 복잡도 – O(N*min(n1, n2)), 길이가 n1과 n2인 부분 문자열을 찾았기 때문입니다.

공간 복잡도 - 부분 문자열을 저장하므로 O(min(n1, n2)입니다.

첫 번째 방법에서는 컬렉션을 사용하여 S2의 시작 인덱스를 저장하는데, 이는 두 번째 방법의 코드보다 더 많은 공간을 필요로 합니다. 두 번째 방법의 코드는 첫 번째 방법보다 읽기 쉽습니다. 또는 프로그래머는 S1이 나타난 후에 하위 문자열 S2가 나타나는지 확인하는 문제를 해결하려고 시도할 수 있습니다.

위 내용은 주어진 문장에서 부분 문자열 S2가 발생한 후에 부분 문자열 S1이 나타나는지 확인합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Teams에서 맞춤법 검사가 작동하지 않음 [수정됨] Teams에서 맞춤법 검사가 작동하지 않음 [수정됨] Mar 06, 2024 am 09:10 AM

때때로 Teams에서 맞춤법 검사가 작동하지 않는 경우가 있다는 사실을 알아차리기 시작했습니다. 맞춤법 검사는 효과적인 의사소통을 위한 필수 도구이며 이에 대한 공격은 작업 흐름에 상당한 혼란을 초래할 수 있습니다. 이 문서에서는 맞춤법 검사가 예상대로 작동하지 않는 일반적인 이유와 이전 상태로 복원하는 방법을 살펴보겠습니다. 따라서 Teams에서 맞춤법 검사가 작동하지 않는 경우 이 문서에 설명된 해결 방법을 따르세요. Microsoft 맞춤법 검사가 작동하지 않는 이유는 무엇입니까? Microsoft 맞춤법 검사가 제대로 작동하지 않는 데에는 여러 가지 이유가 있을 수 있습니다. 이러한 이유에는 호환되지 않는 언어 설정, 맞춤법 검사 기능 비활성화, MSTeam 또는 MSOffice 설치 손상 등이 포함됩니다. 또한 오래된 MSTeams 및 MSOf

Python에서 애플리케이션이 열려 있는지 확인하는 방법은 무엇입니까? Python에서 애플리케이션이 열려 있는지 확인하는 방법은 무엇입니까? Aug 26, 2023 pm 06:49 PM

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

Python에서 객체가 반복 가능한지 확인하는 방법은 무엇입니까? Python에서 객체가 반복 가능한지 확인하는 방법은 무엇입니까? Aug 25, 2023 pm 10:05 PM

반복 가능한 객체는 루프나 반복 가능한 함수를 사용하여 모든 요소를 ​​반복할 수 있는 객체입니다. 목록, 문자열, 사전, 튜플 등을 모두 반복 가능한 객체라고 합니다. Python 언어에는 객체가 반복 가능한지 여부를 확인하는 다양한 방법이 있습니다. 하나씩 살펴보겠습니다. 루프 사용하기 Python에는 두 가지 루프 기술이 있습니다. 하나는 "for" 루프를 사용하고 다른 하나는 "while" 루프를 사용하는 것입니다. 이 두 루프 중 하나를 사용하면 주어진 객체가 반복 가능한지 확인할 수 있습니다. 예제 이 예제에서는 "for" 루프를 사용하여 객체를 반복하고 반복되는지 여부를 확인합니다. 아래는 코드입니다. l=["사과",22,"오렌지색

Windows 11에서 SSD 상태를 확인하는 방법은 무엇입니까? Win11에서 SSD 상태를 확인하는 방법 Windows 11에서 SSD 상태를 확인하는 방법은 무엇입니까? Win11에서 SSD 상태를 확인하는 방법 Feb 14, 2024 pm 08:21 PM

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

ArrayList에 Java의 특정 요소가 포함되어 있는지 확인하는 방법은 무엇입니까? ArrayList에 Java의 특정 요소가 포함되어 있는지 확인하는 방법은 무엇입니까? Sep 03, 2023 pm 04:09 PM

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

Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Mar 12, 2024 pm 09:42 PM

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

TPP 학생이 인터뷰에 적합한지 확인하는 데 사용되는 Java 프로그램 TPP 학생이 인터뷰에 적합한지 확인하는 데 사용되는 Java 프로그램 Sep 06, 2023 pm 10:33 PM

다양한 회사의 자격 기준을 알아보려면 아래 표를 고려하십시오. 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 조건 사용 일반적으로 여러 조건을 확인해야 할 때 사용합니다.

해당 연도가 윤년인지 확인하는 프로그램을 C 언어로 작성하세요. 해당 연도가 윤년인지 확인하는 프로그램을 C 언어로 작성하세요. Sep 20, 2023 pm 03:33 PM

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

See all articles