> 백엔드 개발 > C++ > 문자를 바꿔 배열의 모든 문자열을 동일하게 만들 수 있는지 확인

문자를 바꿔 배열의 모든 문자열을 동일하게 만들 수 있는지 확인

PHPz
풀어 주다: 2023-09-22 23:45:03
앞으로
846명이 탐색했습니다.

문자를 바꿔 배열의 모든 문자열을 동일하게 만들 수 있는지 확인

이 기사에서는 문자를 바꿔 배열의 모든 문자열이 동일한지 확인하는 문제를 살펴보겠습니다. 먼저 문제 설명을 이해한 다음 문제를 해결하는 간단하고 효율적인 방법과 해당 알고리즘 및 시간 복잡도를 연구합니다. 마지막으로 C++로 솔루션을 구현하겠습니다.

문제 설명

문자열 배열이 주어지면 문자를 바꿔서 모든 문자열을 동일하게 만들 수 있는지 확인하세요.

순진한 방법

가장 간단한 방법은 배열에 있는 각 문자열의 문자를 정렬한 후 정렬된 각 문자열을 다음 정렬된 문자열과 비교하는 것입니다. 정렬된 문자열이 모두 같다면 문자를 바꿔서 모든 문자열을 동일하게 만들 수 있다는 의미입니다.

알고리즘(순진한)

  • 배열에 있는 각 문자열의 문자를 정렬합니다.

  • 정렬된 각 문자열을 다음 정렬 문자열과 비교하세요.

  • 정렬된 문자열이 모두 같으면 true를 반환하고, 그렇지 않으면 false를 반환합니다.

C++ 코드(일반)

으아악

출력

으아악

시간 복잡도(순진): O(n * m * log(m)), 여기서 n은 배열에 있는 문자열의 수이고 m은 배열에 있는 문자열의 최대 길이입니다.

효율적인 방법

작동하는 방법은 각 문자열에서 각 문자의 빈도를 계산하고 그 수를 빈도 배열에 저장하는 것입니다. 그런 다음 모든 문자열의 주파수 배열을 비교합니다. 동일하다면 문자를 바꿔서 모든 문자열을 동일하게 만들 수 있다는 의미입니다.

알고리즘(효율적)

  • 배열의 각 문자열에 대한 주파수 배열 벡터를 초기화합니다.

  • 각 문자열에서 각 문자의 발생 빈도를 계산하여 해당 빈도 배열에 저장합니다.

  • 모든 문자열의 주파수 배열을 비교하세요.

  • 모든 주파수 배열이 동일하면 true를 반환하고, 그렇지 않으면 false를 반환합니다.

C++ 코드(효율적)

으아악

출력

으아악

시간 복잡도(효율적) - O(n * m), 여기서 n은 배열에 있는 문자열의 수이고 m은 배열에 있는 문자열의 최대 길이입니다.

결론

이 글에서는 문자를 바꿔서 배열의 모든 문자열이 동일한지 확인하는 문제를 살펴보았습니다. 우리는 이 문제를 해결하기 위한 간단하면서도 효율적인 방법과 알고리즘 및 시간 복잡성을 논의합니다. 이 효율적인 방법은 주파수 배열을 사용하여 문자 발생 횟수를 비교하므로 간단한 방법에 비해 시간 복잡도가 크게 향상됩니다.

위 내용은 문자를 바꿔 배열의 모든 문자열을 동일하게 만들 수 있는지 확인의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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