문자열에 공백 추가
2109. 문자열에 공백 추가
난이도:중
주제: 배열, 두 포인터, 문자열, 시뮬레이션
인덱스가 0인 문자열 s와 공백이 추가될 원래 문자열의 인덱스를 설명하는 인덱스가 0인 정수 배열 공백이 제공됩니다. 각 공백은 해당 인덱스의 문자 앞에 삽입되어야 합니다.
- 예를 들어 s = "EnjoyYourCoffee"이고 공백 = [5, 9]인 경우 각각 인덱스 5와 9에 있는 'Y'와 'C' 앞에 공백을 배치합니다. 그리하여 "Enjoy Your Coffee"를 획득하게 되었습니다.
공백을 추가한 후수정된 문자열을 반환합니다.
예 1:
- 입력: s = "LeetcodeHelpsMeLearn", 공백 = [8,13,15]
- 출력: "Leetcode는 학습에 도움이 됩니다."
-
설명: 인덱스 8, 13, 15는 "LeetcodeHelpsMeLearn"의 밑줄 친 문자에 해당합니다.
- 그런 다음 해당 문자 앞에 공백을 넣습니다.
예 2:
- 입력: s = "icodeinpython", 공백 = [1,5,7,9]
- 출력: "i code in py thon"
-
설명: 인덱스 1, 5, 7, 9는 "icodeinpython"의 밑줄 친 문자에 해당합니다.
- 그런 다음 해당 문자 앞에 공백을 넣습니다.
예 3:
- 입력: s = "간격", 공백 = [0,1,2,3,4,5,6]
- 출력: "s p a c i ng"
- 설명: 문자열의 첫 문자 앞에 공백을 넣을 수도 있습니다.
제약조건:
- 1 5
- s는 영문 소문자와 대문자로만 구성됩니다.
- 1 <= 공백.길이 <= 3 * 105
- 0 <= 공백[i] <= s.length - 1
- 공간의 모든 가치는 엄청나게 증가합니다.
힌트:
- 수정된 문자열로 처음에는 비어 있는 새 문자열을 만듭니다. 원래 문자열을 반복하고 원래 문자열의 각 문자를 새 문자열에 추가합니다. 그러나 앞에 공백이 필요한 문자에 도달할 때마다 문자를 추가하기 전에 공백을 추가하십시오.
- 공간 위치에 대한 색인 배열이 정렬되어 있으므로 포인터를 사용하여 공간을 배치할 다음 색인을 추적하세요. 공백이 추가된 후에만 포인터를 증가시키세요.
- 추가 작업이 O(1)에서 수행될 수 있는지 확인하세요.
해결책:
두 개의 포인터를 사용하여 효율적인 접근 방식을 사용할 수 있습니다. PHP 5.6의 구현은 다음과 같습니다.
솔루션 설명:
- 포인터 spaceIndex를 사용하여 공백 배열의 현재 위치를 추적하세요.
- 루프를 사용하여 문자열 s를 반복합니다.
- 문자열의 현재 인덱스가 공백 배열의 현재 값과 일치하는지 확인하세요. 그렇다면 결과에 공백을 추가하고 spaceIndex 포인터를 앞으로 이동하세요.
- 현재 문자열 문자를 결과에 추가합니다.
- 최종 결과를 단일 문자열로 반환합니다.
이 접근 방식을 사용하면 공백 배열의 정렬된 순서를 활용하여 입력을 효율적으로 처리할 수 있습니다.
이 솔루션을 PHP로 구현해 보겠습니다: 2109. 문자열에 공백 추가
설명:
- 효율적인 추가: . PHP의 연산자는 문자열을 효율적으로 추가하는 데 사용됩니다.
- 두 개의 포인터: spaceIndex 포인터는 공백 배열을 한 번만 처리하도록 보장합니다.
- 시간 복잡성:
- 문자열을 반복하려면 O(n)이 필요합니다. 여기서 n은 문자열의 길이입니다.
- 공백 배열 포인터를 확인하려면 O(m)이 필요합니다. 여기서 m은 공백 배열의 길이입니다.
- 결합: O(n m), 이는 제약 조건을 고려할 때 최적입니다.
이 솔루션은 제약 조건을 준수하며 대규모 입력에도 효율적입니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
위 내용은 문자열에 공백 추가의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











Laravel Back End : Part 2, React가있는 React 앱 구축

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법
