>백엔드 개발 >C++ >겹치지 않는 세 개의 하위 문자열을 계산하고 이를 연결하여 회문을 형성합니다.

겹치지 않는 세 개의 하위 문자열을 계산하고 이를 연결하여 회문을 형성합니다.

王林
王林앞으로
2023-09-07 18:25:021295검색

겹치지 않는 세 개의 하위 문자열을 계산하고 이를 연결하여 회문을 형성합니다.

소개

이 튜토리얼에서는 주어진 문자열 s에서 겹치지 않는 세 개의 하위 문자열을 찾고, 모든 하위 문자열이 함께 결합되면 회문을 형성하는 방법에 대해 자세히 설명합니다. 이 작업을 해결하기 위해 C++ 프로그래밍 언어의 문자열 클래스 기능을 사용합니다.

문자열의 회문은 문자열이 앞뒤 방향 모두 동일하게 읽힌다는 것을 의미합니다. 회문 문자열의 예는 Madam입니다.

문자열 "s"가 있고 하위 문자열이 a, b, c라고 가정합니다. a, b, c를 결합하면 회문 문자열이 형성됩니다. 이것은 문제의 논리를 이해하는 예입니다.

문장 설명

으아아아

세 개의 하위 문자열을 모두 연결하면 결과 문자열은 abbbacbba인 회문 문자열이 됩니다.

문법

size() 함수는 문자열 클래스에 속하며 입력 문자열의 크기와 문자 길이를 얻는 데 사용됩니다.

으아아아

알고리즘

  • 입력 문자열을 가져옵니다.

  • 회문 부분 문자열 수를 추적하는 데 사용되는 카운터 변수를 초기화합니다.

  • 3개의 중첩된 for 루프를 사용하여 정의된 길이의 가능한 하위 문자열 3개를 생성하세요.

  • 첫 번째 내부 루프는 0에서 문자열 길이 - 3으로 초기화됩니다.

  • 두 번째 내부 루프는 첫 번째 내부 루프의 문자열 길이 - 2 + 1로 초기화됩니다.

  • 외부 루프는 두 번째 루프 + 1부터 문자열 길이 - 1까지 초기화됩니다.

  • 모든 하위 문자열을 찾은 후 연결하세요.

  • 하위 문자열 회문이 존재하는지 확인하고 존재하는 경우 카운터 변수 값을 증가시킵니다.

  • 카운터 변수 값을 인쇄합니다.

C++를 사용하여 위 알고리즘을 구현하기 위해 입력 문자열을 가져와 가능한 모든 하위 문자열 조합을 생성하고 해당 회문 하위 문자열만 고려합니다. 그러한 하위 문자열이 가능하면 카운터 변수가 증가됩니다. 카운터 변수의 결과를 인쇄합니다.

으아아아

출력

으아아아

결론

우리는 회문을 형성하는 유효한 하위 문자열을 찾는 방법을 개발했습니다. 이 솔루션을 구현하기 위해 C++ 루프와 if 조건을 사용했습니다. C++를 사용하여 예제 중 하나를 구현하기 위해 size() 함수와 중첩 루프를 사용했습니다. 중첩 루프는 길이가 다른 하위 문자열을 찾는 데 도움이 되며 size() 함수는 문자열의 크기를 반환합니다.

위 내용은 겹치지 않는 세 개의 하위 문자열을 계산하고 이를 연결하여 회문을 형성합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 tutorialspoint.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제