> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 프로그램은 문자열이 서로에 대해 회전하는지 확인합니다.

JavaScript 프로그램은 문자열이 서로에 대해 회전하는지 확인합니다.

PHPz
풀어 주다: 2023-09-22 13:53:23
앞으로
921명이 탐색했습니다.

JavaScript 程序检查字符串是否相互旋转

줄이 서로 회전한다는 것은 두 개의 줄을 오른쪽이나 왼쪽으로 회전하여 다른 줄을 얻을 수 있다는 의미입니다. 문자열의 오른쪽으로 회전된 문자에서 다음 인덱스로 이동하고, 문자열이 원 안에 있다고 가정하고 0번째 인덱스의 경우 마지막 인덱스의 문자를 가져옵니다. 왼쪽 회전은 오른쪽 회전과 유사하지만 반대 방향입니다. 두 개의 문자열이 주어지고 한 문자열의 문자를 회전하여 다른 문자열을 얻을 수 있는지 결정해야 합니다.

들어가세요

으아아아

출력

으아아아

설명: 첫 번째 문자열을 왼쪽으로 두 번 회전하여 두 번째 문자열을 얻을 수 있습니다. 첫 번째 루프 이후의 String1은 "bcdefa"가 되고 다음 루프에서는 두 번째 문자열과 동일하게 됩니다.

들어가세요

으아아아

출력

으아아아

설명 - 원래 문자열을 가져오지 않고 문자열이나 배열을 회전할 수 있는 최대 회전 수는 주어진 문자열이나 배열의 길이와 같습니다.

여기서 6회전 후에는 문자열 1에서 문자열 2를 얻을 수 없으며, 이는 최대 회전 수 이후 두 문자열을 동일하게 만드는 것이 불가능하다는 것을 증명합니다.

순진한 방법

이 방법에서는 주어진 문자열을 길이만큼 회전하고 다른 주어진 문자열과 일치시킵니다.

으아아아

출력

으아아아

시간과 공간의 복잡성

위 코드의 시간 복잡도는 O(N*N)입니다. 여기서 N은 주어진 문자열의 크기입니다.

위 코드의 공간 복잡도는 공간을 사용하지 않기 때문에 O(1)입니다.

KMP 알고리즘

이 프로그램에서는 KMP 알고리즘을 사용하여 회전을 찾습니다. 코드로 이동해 보겠습니다.

으아아아

출력

으아아아

시간과 공간의 복잡성

위 프로그램의 경우 시간 복잡도와 공간 복잡도는 모두 O(N)입니다. lps 배열에 값을 저장하기 위해 추가 공간을 사용합니다.

결론

이 튜토리얼에서는 문자열의 문자를 왼쪽이나 오른쪽으로 회전하여 주어진 문자열을 다른 주어진 문자열에서 얻을 수 있는지 확인하는 JavaScript 프로그램을 구현했습니다. 우리는 O(N*N) 시간 복잡도와 O(1) 공간 복잡도를 취하는 순진한 접근 방식을 사용했습니다. 또한 O(N) 시간 및 공간 복잡도를 갖는 KMP 알고리즘을 구현했습니다.

위 내용은 JavaScript 프로그램은 문자열이 서로에 대해 회전하는지 확인합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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