1639. 사전이 주어지면 대상 문자열을 형성하는 방법의 수
난이도:어려움
주제: 배열, 문자열, 동적 프로그래밍
같은 길이 단어의 문자열 목록과 문자열 대상이 제공됩니다.
당신의 임무는 다음 규칙에 따라 주어진 단어를 사용하여 타겟을 형성하는 것입니다.
- 타겟은 왼쪽에서 오른쪽으로 형성되어야 합니다.
- 대상의 i번째 문자(0-색인)를 구성하려면 j번째번째 문자를 선택할 수 있습니다. 🎜> target[i] = 단어[j][k]인 경우 단어로 된 문자열. j
- 번째 단어 문자열에서 k번째 문자를 사용하면 x번째를 더 이상 사용할 수 없습니다. x 문자열 타겟이 형성될 때까지 이 과정을 반복하세요.
주의 위의 조건이 충족되면 단어에서 동일 문자열의 여러 문자를 사용할 수 있습니다.
단어에서 대상을 형성하는 방법의 수를 반환합니다. 답이 너무 클 수 있으므로 모듈로 109 7로 반환하세요.
예 1:
- 입력: 단어 = ["acca","bbbb","caca"], 대상 = "aba"
- 출력: 6
- 설명: 타겟을 형성하는 방법에는 6가지가 있습니다.
- "아바" -> 인덱스 0("acca"), 인덱스 1("bbbb"), 인덱스 3("caca")
- "아바" -> 인덱스 0("acca"), 인덱스 2("bbbb"), 인덱스 3("caca")
- "아바" -> 인덱스 0("acca"), 인덱스 1("bbbb"), 인덱스 3("acca")
- "아바" -> 인덱스 0("acca"), 인덱스 2("bbbb"), 인덱스 3("acca")
- "아바" -> 인덱스 1("caca"), 인덱스 2("bbbb"), 인덱스 3("acca")
- "아바" -> 인덱스 1("caca"), 인덱스 2("bbbb"), 인덱스 3("caca")
예 2:
- 입력: 단어 = ["abba","baab"], 대상 = "bab"
- 출력: 4
- 설명: 타겟을 형성하는 방법에는 4가지가 있습니다.
- "밥" -> 인덱스 0("baab"), 인덱스 1("baab"), 인덱스 2("abba")
- "밥" -> 인덱스 0("baab"), 인덱스 1("baab"), 인덱스 3("baab")
- "밥" -> 인덱스 0("baab"), 인덱스 2("baab"), 인덱스 3("baab")
- "밥" -> 인덱스 1("abba"), 인덱스 2("baab"), 인덱스 3("baab")
제약조건:
- 1
- 1
- 단어에 포함된 모든 문자열의 길이는 동일합니다.
- 1
- word[i] 및 target에는 영문 소문자만 포함됩니다.
힌트:
- 각 인덱스 i에 대해 i번째 행에 각 문자의 빈도를 저장합니다.
- 동적 프로그래밍을 이용하여 주파수 배열을 이용하여 목표 문자열을 얻는 방법의 수를 계산해 보세요.
해결책:
이 문제는 문자 사용에 대한 특정 규칙에 따라 단어 사전에서 대상 문자열을 형성하는 방법의 수를 찾는 것입니다. 이는 동적 프로그래밍(DP)과 문자 빈도 전처리
를 사용하여 효율적으로 풀 수 있는 조합 문제입니다.핵심사항
-
제약조건:
- 단어의 길이가 같습니다.
- 단어 문자는 왼쪽에서 오른쪽으로만 사용할 수 있습니다.
-
도전:
- 큰 제약으로 인해 타겟 형성 방법을 효율적으로 계산합니다.
- 메모이제이션으로 재계산을 방지하세요.
-
모듈로:
- 결과가 클 수 있으므로 모든 계산은 모듈로 109 7로 수행됩니다.
접근방법
솔루션은 다음을 사용합니다.
-
전처리:
- 모든 단어의 모든 위치에서 각 문자의 빈도를 계산합니다.
-
동적 프로그래밍:
- 2D DP 테이블을 사용하여 대상 문자열을 구성하는 방법의 수를 계산합니다.
단계:
- 단어를 빈도 배열(개수)로 전처리합니다.
- 전처리된 개수를 사용하여 타겟을 형성하는 방법의 수를 반복적으로 찾는 DP 함수를 정의합니다.
계획
-
입력 구문 분석:
- 단어와 대상을 받아들입니다.
-
전처리:
- counts[j][char]가 모든 단어에서 j 위치의 char 빈도를 나타내는 counts 배열을 만듭니다.
-
동적 프로그래밍:
- 메모이제이션과 함께 재귀 함수를 사용하여 단어의 유효한 위치에 있는 문자를 사용하여 타겟을 형성하는 방법의 수를 계산합니다.
-
결과 반환:
- 총 개수를 모듈로 10으로 반환9 7.
PHP에서 이 솔루션을 구현해 보겠습니다. 1639. 사전이 주어지면 대상 문자열을 형성하는 방법의 수
<?php const MOD = 1000000007; /** * @param String[] $words * @param String $target * @return Integer */ function numWays($words, $target) { ... ... ... /** * go to ./solution.php */ } /** * Helper function for DP * * @param $i * @param $j * @param $counts * @param $target * @param $memo * @return float|int|mixed */ private function dp($i, $j, $counts, $target, &$memo) { ... ... ... /** * go to ./solution.php */ } // Example Usage $words = ["acca", "bbbb", "caca"]; $target = "aba"; echo numWays($words, $target) . "\n"; // Output: 6 $words = ["abba", "baab"]; $target = "bab"; echo numWays($words, $target) . "\n"; // Output: 4 ?>
설명:
-
전처리 단계:
- 개수 배열 구축:
- 단어의 각 열에 대해 각 문자의 발생 횟수를 셉니다.
- 예: 단어 = ["acca", "bbbb", "caca"]인 경우 첫 번째 열에 대해 counts[0] = {'a': 1, 'b': 1, 'c': 1 }.
- 개수 배열 구축:
-
재귀 DP:
- dp(i, j) 정의:
- i는 타겟의 현재 인덱스입니다.
- j는 단어로 표현된 현재 위치입니다.
- 기본 사례:
- i == len(target)인 경우: 전체 대상이 형성됨 → 1을 반환합니다.
- j == len(words[0])인 경우: 더 이상 사용할 열이 없으며 → 0을 반환합니다.
- 반복:
- 옵션 1: j 위치의 counts[j][target[i]] 문자를 사용합니다.
- 옵션 2: 위치 j를 건너뜁니다.
- dp(i, j) 정의:
-
최적화:
- 메모이제이션 테이블을 사용해 중복된 하위 문제의 결과를 저장하세요.
예시 연습
입력:
단어 = ["acca", "bbbb", "caca"], 대상 = "aba"
-
전처리:
- 개수[0] = {'a': 2, 'b': 0, 'c': 1}
- 개수[1] = {'a': 0, 'b': 3, 'c': 0}
- 개수[2] = {'a': 1, 'b': 0, 'c': 2}
- 개수[3] = {'a': 2, 'b': 0, 'c': 1}
-
DP 계산:
- dp(0, 0): 0열부터 시작하여 "aba"를 형성하는 방법의 수.
- 카운트 사용과 열 건너뛰기를 결합하여 재귀적으로 계산합니다.
출력: 6
시간복잡도
- 전처리: O(n x m), 여기서 n은 단어 수이고 m은 단어 길이입니다.
- 동적 프로그래밍: O(l x m), 여기서 l은 대상의 길이입니다.
- 합계: O(n x m l x m).
예시 출력
- 입력: 단어 = ["acca", "bbbb", "caca"], 대상 = "aba"
- 출력: 6
이 문제는 조합 문제를 효율적으로 해결하기 위해 전처리와 동적 프로그래밍을 결합한 훌륭한 예입니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
위 내용은 사전이 주어지면 대상 문자열을 형성하는 방법의 수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

PHP 다차원 어레이에서 총 요소 수를 계산하는 것은 재귀 적 또는 반복적 인 방법을 사용하여 수행 할 수 있습니다. 1. 재귀 방법은 배열을 가로 지르고 중첩 배열을 재귀 적으로 처리함으로써 계산됩니다. 2. 반복 방법은 스택을 사용하여 깊이 문제를 피하기 위해 재귀를 시뮬레이션합니다. 3. Array_Walk_Recursive 함수도 구현할 수 있지만 수동 계산이 필요합니다.

PHP에서, do-while 루프의 특성은 루프 본체가 적어도 한 번 실행되도록하고 조건에 따라 루프를 계속할지 여부를 결정하는 것입니다. 1) 조건부 점검 전에 루프 본체를 실행하며, 사용자 입력 확인 및 메뉴 시스템과 같이 작업을 적어도 한 번 수행 해야하는 시나리오에 적합합니다. 2) 그러나, do-while 루프의 구문은 초보자들 사이에서 혼란을 야기 할 수 있으며 불필요한 성능 오버 헤드를 추가 할 수 있습니다.

PHP의 효율적인 해싱 스트링은 다음 방법을 사용할 수 있습니다. 1. 빠른 해싱에 MD5 기능을 사용하지만 비밀번호 저장에는 적합하지 않습니다. 2. SHA256 기능을 사용하여 보안을 향상시킵니다. 3. Password_hash 함수를 사용하여 비밀번호를 처리하여 최고 보안과 편의성을 제공하십시오.

PHP에서 배열 슬라이딩 윈도우 구현 기능은 SlideWindow 및 SlideWindowAverage 기능으로 수행 할 수 있습니다. 1. Slide-Window 함수를 사용하여 배열을 고정 크기 서브 어레이로 분할하십시오. 2. SlideWindowAverage 함수를 사용하여 각 창의 평균 값을 계산하십시오. 3. 실시간 데이터 스트림의 경우, 비동기 처리 및 이상치 감지를 Reactphp를 사용하여 사용할 수 있습니다.

PHP의 __clone 방법은 객체 클로닝시 사용자 정의 작업을 수행하는 데 사용됩니다. 클론 키워드를 사용하여 객체를 클로닝 할 때 객체에 __ 클론 메소드가있는 경우 방법이 자동으로 호출되어 클로닝 프로세스 중에 클로닝 된 객체의 독립성을 보장하기 위해 참조 유형 속성을 재설정하는 것과 같은 클로닝 프로세스 중에 맞춤형 처리가 가능합니다.

PHP에서 GOTO 진술은 프로그램의 특정 태그로 무조건 점프하는 데 사용됩니다. 1) 복잡한 중첩 루프 또는 조건부 명세서의 처리를 단순화 할 수 있지만 2) GOTO를 사용하면 코드를 이해하고 유지하기가 어렵게 만들 수 있으며 3) 구조화 된 제어 문의 사용에 우선 순위를 부여하는 것이 좋습니다. 전반적으로, GOTO는 조심스럽게 사용해야하며 모범 사례를 따라 코드의 가독성과 유지 보수 가능성을 보장합니다.

PHP에서 내장 기능, 사용자 정의 기능 및 타사 라이브러리를 사용하여 데이터 통계를 달성 할 수 있습니다. 1) array_sum () 및 count ()와 같은 내장 함수를 사용하여 기본 통계를 수행하십시오. 2) 중앙값과 같은 복잡한 통계를 계산하기 위해 사용자 정의 기능을 작성하십시오. 3) PHP-ML 라이브러리를 사용하여 고급 통계 분석을 수행하십시오. 이러한 방법을 통해 데이터 통계를 효율적으로 수행 할 수 있습니다.

예, PHP의 익명 함수는 이름이없는 함수를 나타냅니다. 다른 함수의 매개 변수로 전달되고 함수의 리턴 값으로 전달 될 수있어 코드를보다 유연하고 효율적으로 만듭니다. 익명 기능을 사용하는 경우 범위 및 성능 문제에주의를 기울여야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Dreamweaver Mac版
시각적 웹 개발 도구