> 백엔드 개발 > C++ > 본문

주어진 하위 문자열에 정확히 K 1이 포함되도록 만드는 데 필요한 최소 교환 횟수는 얼마입니까?

王林
풀어 주다: 2023-08-25 23:25:10
앞으로
675명이 탐색했습니다.

주어진 하위 문자열에 정확히 K 1이 포함되도록 만드는 데 필요한 최소 교환 횟수는 얼마입니까?

부분 문자열이 정확히 K개를 포함하는 데 필요한 최소 스왑 수를 찾는 것은 컴퓨터 과학 및 프로그래밍에서 일반적인 문제입니다. 이 기사에서는 이 문제를 자세히 조사하고 이에 대한 C++ 솔루션을 제공합니다. 이 질문은 문자열 조작, 데이터 구조 최적화, 인터뷰 코딩 문제 등 다양한 분야에 적용됩니다.

문제 설명

이진 문자열과 숫자 K가 주어지면 문자열의 각 하위 문자열이 정확히 K개의 문자열을 갖도록 보장하는 데 필요한 최소 스왑 수를 찾는 것이 과제입니다.

방법

이 문제를 해결하기 위해 두 포인터 방법과 슬라이딩 윈도우 기술을 사용할 수 있습니다. 기본 아이디어는 K 크기의 창을 유지하고 창의 모든 1에 필요한 스왑 수를 계산하는 것입니다.

위 메소드를 구현한 C++ 함수입니다 -

으아아아

출력

으아아아

테스트 케이스 설명

문자열이 "10010110", K = 3이라고 가정합니다.

초기 이진 문자열 "10010110"에서 크기 3의 각 하위 문자열에 정확히 3개의 1이 있어야 합니다. 예를 들어 하위 문자열 "100"이 "111"이 되려면 2번의 교환이 필요합니다. 마찬가지로 하위 문자열 "001"에도 2번의 교환이 필요합니다. 문자열을 반복함으로써 하위 문자열 "101"에 필요한 최소 스왑 수가 1이라는 것을 알 수 있습니다.

결론

이 질문은 알고리즘, 데이터 구조 및 C++ 언어에 대한 이해를 결합하여 복잡한 문제를 해결하는 방법을 보여주는 훌륭한 예입니다. 이러한 질문을 이해하고 구현하는 것은 소프트웨어 엔지니어, 특히 코딩 인터뷰 및 경쟁 프로그래밍에 매우 도움이 될 수 있습니다.

위 내용은 주어진 하위 문자열에 정확히 K 1이 포함되도록 만드는 데 필요한 최소 교환 횟수는 얼마입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿