Q 쿼리의 경우 다음을 중국어로 번역합니다. 삼항 문자열에서 모든 회문 하위 문자열을 제거하기 위해 바꿔야 하는 최소 문자 수
회문 문자열은 반전된 문자열과 동일한 문자열입니다. '0', '1', '2'를 포함하는 문자열과 길이 N의 배열 Q가 주어지면, 주어진 배열의 각 인덱스는 범위를 나타내며, 범위는 형식의 값 쌍으로 표시됩니다. 범위에 회문 하위 문자열이 없는지 확인하기 위해 지정된 범위에서 바꿔야 하는 최소 문자 수를 찾아야 합니다.
예제 예
으아악 으아악Explanation
의 중국어 번역은Explanation
입니다.0부터 4까지의 범위에는 두 개의 회문 010과 1001이 있습니다. 회문이 남지 않도록 인덱스 2를 '2'로 변경할 수 있습니다.
2~5 범위의 경우 회문 번호는 010 하나만 있으며 첫 번째 0을 2로 변경하여 변경할 수 있습니다.
5~10 범위의 숫자에는 회문 번호 020, 000 및 20002가 있습니다. 모든 회문을 제거하려면 처음 2를 '1'로, 다음 인덱스의 '0'을 '2'로, 두 번째부터 마지막 인덱스의 값을 '1'로 변경할 수 있습니다.
Naive Approach
의 중국어 번역은Naive Approach
입니다.이 방법의 아이디어는 주어진 범위의 모든 조합을 얻고 회문 없이 조합에 필요한 최소 변경 횟수를 찾는 것입니다. 하지만 문제는 시간복잡도이다.
이 방법을 구현하려면 재귀 호출을 수행하고 문자열을 반복해야 합니다. 각 인덱스에는 세 가지 선택 사항이 있으므로 모든 문자열을 3^N으로 만드는 데 시간이 복잡해집니다. 이제 우리는 Q 쿼리에 응답해야 하며 각 경우에 대해 회문 문자열을 제거하면 시간 복잡도가 O(Q*N*(3^N))이 되는지 확인해야 합니다.
재귀 호출의 경우 공간 N을 유지해야 합니다. 이는 공간 복잡도가 O(N)임을 의미합니다.
동적 계획
Idea
의 중국어 번역은Idea
입니다.이 질문의 아이디어는 주어진 범위에서 회문 번호를 찾을 필요가 없다는 것입니다. 가능한 최소 회문 길이는 짝수의 경우 2이고 홀수의 경우 3입니다.
우리는 세 가지 다른 문자를 가지고 있으며 회문 없이 주어진 문자열을 만들려면 이들 모두가 필요합니다. 전체 크기 선택 또는 시퀀스가 있습니다. 회문이 존재하지 않는 방식으로 시퀀스를 형성할 수 있으며 이러한 시퀀스는 문자열 '012'의 순열입니다.
dp 배열이나 벡터를 사용하여 가능한 모든 사례를 저장하고 각 시퀀스는 더 적은 수의 문자를 제공하며 해당 시퀀스를 사용합니다.
구현
구현 부분에서는 먼저 문자열, 시퀀스, DP 벡터 및 시퀀스 수를 매개변수로 받아들이고 DP 벡터를 업데이트하는 함수를 생성합니다.
이 함수에서는 먼저 첫 번째 인덱스 값을 업데이트한 다음 일치하지 않는 각 사례에 대해 DP 벡터의 현재 인덱스 값을 업데이트합니다.
가능한 모든 시퀀스를 수동으로 입력하고 이를 배열에 저장하고 DP 벡터를 생성하는 또 다른 함수를 만들어 보겠습니다.
전처리를 위한 값을 전달하여 위 함수를 호출한 후 하나씩 처리하여 각 쿼리에 응답하겠습니다.
Example
의 중국어 번역은Example
입니다. 으아악출력
으아악시간과 공간의 복잡성
위 코드의 시간 복잡도는 O(N + Q)입니다. 여기서 N은 문자열의 문자 수이고 Q는 쿼리 수입니다.
위 코드의 공간 복잡도는 O(N)입니다. 왜냐하면 상태를 N 크기의 벡터에 저장하기 때문입니다.
결론
이 튜토리얼에서는 회문 문자열을 남기지 않도록 특정 범위에서 일부 쿼리를 수행할 때 변경해야 하는 최소 문자 수를 알아내는 코드를 구현했습니다. 우리는 시간 복잡도가 O(N+Q)이고 공간 복잡도가 O(N)인 동적 프로그래밍 개념을 사용하여 이 코드를 구현했습니다.
위 내용은 Q 쿼리의 경우 다음을 중국어로 번역합니다. 삼항 문자열에서 모든 회문 하위 문자열을 제거하기 위해 바꿔야 하는 최소 문자 수의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











PyCharm은 개발자가 프로그래밍 효율성을 향상시키는 데 도움이 될 수 있는 풍부한 기능과 단축키를 갖춘 일반적으로 사용되는 Python 통합 개발 환경입니다. 일상적인 프로그래밍 과정에서 PyCharm의 단축키 교체 기술을 익히면 개발자가 작업을 더 빠르게 완료하는 데 도움이 될 수 있습니다. 이 문서에서는 프로그래밍 속도를 쉽게 향상시키는 데 도움이 되도록 PyCharm에서 일반적으로 사용되는 대체 단축키를 소개합니다. 1.Ctrl+R 교체 PyCharm에서는 Ctrl+R 단축키를 사용하여 교체 작업을 수행할 수 있습니다.

Java의 StringBuilder.replace() 함수를 사용하여 지정된 문자 범위를 바꿉니다. Java에서 StringBuilder 클래스는 문자열에서 지정된 문자 범위를 바꾸는 데 사용할 수 있는 replacement() 메서드를 제공합니다. 이 메서드의 구문은 다음과 같습니다. publicStringBuilderreplace(intstart,intend,Stringstr) 위 메서드는 인덱스 별표를 바꾸는 데 사용됩니다.

PyCharm은 개발 효율성을 크게 향상시킬 수 있는 풍부한 기능과 도구를 갖춘 강력한 Python 통합 개발 환경입니다. 그 중 교체 기능은 개발 과정에서 자주 사용되는 기능 중 하나로, 개발자가 코드를 빠르게 수정하고 코드 품질을 향상시키는 데 도움을 줄 수 있습니다. 이 기사에서는 초보자가 이 기능을 더 잘 익히고 사용할 수 있도록 특정 코드 예제와 함께 PyCharm의 대체 기능을 자세히 소개합니다. 대체 기능 소개 PyCharm의 대체 기능은 개발자가 코드에서 지정된 텍스트를 빠르게 대체하는 데 도움이 될 수 있습니다.

jQuery는 웹 개발에 널리 사용되는 클래식 JavaScript 라이브러리로, 이벤트 처리, DOM 요소 조작, 웹 페이지에서 애니메이션 수행과 같은 작업을 단순화합니다. jQuery를 사용할 때 요소의 클래스 이름을 바꿔야 하는 상황이 자주 발생합니다. 이 기사에서는 몇 가지 실용적인 방법과 구체적인 코드 예제를 소개합니다. 1. RemoveClass() 및 addClass() 메소드 사용 jQuery는 삭제를 위한 RemoveClass() 메소드를 제공합니다.

PyCharm은 프로그래머들 사이에서 인기 있는 통합 개발 환경으로 프로그래밍을 더욱 효율적이고 편리하게 만들어주는 강력한 기능과 도구를 제공합니다. PyCharm에서는 단축키의 합리적인 설정과 교체가 프로그래밍 효율성을 높이는 열쇠 중 하나입니다. 이 기사에서는 프로그래밍을 보다 편리하게 만들기 위해 PyCharm에서 단축키를 대체하는 방법을 소개합니다. 1. 단축키를 대체해야 하는 이유 PyCharm에서 단축키는 프로그래머가 다양한 작업을 빠르게 완료하고 프로그래밍 효율성을 향상시키는 데 도움이 됩니다. 그러나 사람마다 습관이 다르기 때문에 어떤 사람들은 그럴 수도 있습니다.

MySQL은 데이터를 처리하고 운영하는 다양한 기능을 제공하는 일반적으로 사용되는 관계형 데이터베이스 관리 시스템입니다. 그 중 REPLACE 함수는 문자열의 지정된 부분을 바꾸는 데 사용됩니다. 이 기사에서는 MySQL에서 문자열 교체를 위해 REPLACE 함수를 사용하는 방법을 소개하고 코드 예제를 통해 사용법을 보여줍니다. 먼저 REPLACE 함수의 구문인 REPLACE(str,search_str,replace_str)를 살펴보겠습니다.

Python에서는 openpyxl이라는 타사 Python 라이브러리를 사용하여 Excel에서 한 단어를 다른 단어로 바꿀 수 있습니다. Microsoft Excel은 데이터를 관리하고 분석하는 데 유용한 도구입니다. Python을 사용하면 일부 Excel 데이터 관리 작업을 자동화할 수 있습니다. 이번 글에서는 Python을 사용하여 Excel에서 단어를 바꾸는 방법을 알아봅니다. Excel에서 Word를 대체하기 위해 openpyxl을 설치하기 전에 Python 패키지 관리자를 사용하여 시스템에 openpyxl 라이브러리를 설치해야 합니다. openpyxl을 설치하려면 터미널이나 명령 프롬프트에 다음 명령을 입력하세요. 피핀스트

PyCharm은 개발자들에게 널리 사랑받고 있는 Python 통합 개발 환경으로, 코드를 빠르게 교체할 수 있는 다양한 방법을 제공하여 개발 프로세스를 더욱 효율적으로 만듭니다. 이 기사에서는 PyCharm에서 코드를 빠르게 대체하기 위해 일반적으로 사용되는 몇 가지 방법을 공개하고 개발자가 이러한 기능을 더 잘 사용할 수 있도록 구체적인 코드 예제를 제공합니다. 1. 교체 기능 사용 PyCharm은 개발자가 코드에서 텍스트를 빠르게 교체하는 데 도움이 되는 강력한 교체 기능을 제공합니다. 단축키 Ctrl+R을 사용하거나 편집기에서 마우스 오른쪽 버튼을 클릭하고 Re를 선택합니다.
