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

연결리스트에서 가장 자주 나타나는 문자

WBOY
풀어 주다: 2023-08-28 21:01:06
앞으로
1254명이 탐색했습니다.

연결리스트에서 가장 자주 나타나는 문자

단일 연결된 문자 목록이 주어지고, 우리의 임무는 연결된 목록에 가장 자주 나타나는 문자를 인쇄하는 것입니다. 여러 문자가 동일한 횟수만큼 나타나면 해당 문자의 마지막 발생이 인쇄됩니다.

단일 연결 리스트는 노드로 구성된 선형 데이터 구조입니다. 각 노드에는 데이터와 다음 노드에 대한 포인터가 포함되어 있는데, 각 노드에 할당된 메모리는 연속적이지 않기 때문에 다음 노드의 메모리 주소를 포함합니다.

캐릭터 링크 목록이 주어졌다고 가정해보세요

예 1

입력: LL = a -> b -> c -> c -> c

출력: 가장 일반적인 문자는 c입니다.

설명: 주어진 연결 리스트 LL에서 a는 한 번 나타나고, b는 한 번 나타나고, c는 3번 나타납니다. 따라서 출력은 c입니다.

예 2

입력:

LL = x -> x -> y -> y -> z -> z

출력: 가장 많이 나타나는 문자는 z입니다.

설명: 주어진 연결 리스트 LL에서 x는 2번, y는 2번, z는 2번 나타납니다. z가 마지막에 나타나므로 모든 발생은 동일하므로 출력은 z입니다.

여기에서는 두 가지 방법에 대해 논의하겠습니다. 아래 부분을 살펴보도록 하겠습니다 -

방법 1: 반복적으로 빈도 계산

이 방법의 아이디어는 연결된 목록을 순회하여 각 문자의 빈도를 계산한 다음 빈도가 가장 높은 문자를 찾고, 여러 문자의 빈도가 동일한 경우 해당 문자를 인쇄하고 마지막 문자를 반환하는 것입니다. .

으아아아

출력

으아아아

시간 복잡도

: O(N*N), 여기서 N은 연결 목록의 크기입니다.

공간 복잡도: O(1)

방법 2: 계산 배열 사용

이 방법의 아이디어는 각 문자의 빈도를 저장한 다음 배열을 반복하여 가장 높은 빈도의 문자를 찾는 카운트 배열을 유지하는 것입니다. 여러 문자의 빈도가 동일한 경우 해당 문자를 인쇄한 다음 마지막 문자를 반환합니다.

으아아아

출력

으아아아

시간 복잡도

O(N), 여기서 N은 연결 목록의 크기입니다.

공간 복잡도: O(N), 여기서 N은 연결 목록의 크기입니다.

결론

여기에서는 연결 목록에서 가장 자주 사용되는 문자를 찾는 방법에 대해 설명합니다. 최대 문자 발생을 찾기 위해 두 가지 방법을 논의했습니다. 첫 번째 방법은 주어진 연결 목록의 각 문자에 대해 while 루프를 사용하고 두 번째 방법은 각 소문자에 대해 for 루프를 사용하고 개수를 유지합니다.

위 내용은 연결리스트에서 가장 자주 나타나는 문자의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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