일반적인 문제 선형 연결 목록은 선형 목록의 연결 저장 구조입니까?

선형 연결 목록은 선형 목록의 연결 저장 구조입니까?

Oct 24, 2019 am 09:50 AM
선의

데이터 구조의 각 데이터 요소 간 관계의 복잡성에 따라 데이터 구조는 일반적으로 선형 구조와 비선형 구조라는 두 가지 주요 유형으로 나뉩니다.

선형 연결 목록은 선형 목록의 연결 저장 구조입니까?

선형 연결 목록은 이름에서 알 수 있듯이 체인 목록과 유사합니다. 선형 연결 목록의 반대는 선형 시퀀스 목록입니다. 메모리에서 연속적인 영역을 열어야 하므로 메모리에 저장된 데이터의 상태는 연속적인 반면, 선형 연결 목록의 메모리 저장은 무작위이며 데이터 간의 연결은 포인터에 의존합니다. (추천 학습: 웹 프론트 엔드 비디오 튜토리얼)

비어 있지 않은 데이터 구조가 다음 두 가지 조건을 만족하는 경우:

①루트 노드는 하나만 있고

②각 노드에는 최대 하나의 선행 항목이 있습니다. 또한 최대 하나의 결과가 있습니다. 데이터 구조를 선형 구조라고 하며 선형 테이블이라고도 합니다. 따라서 선형 목록, 스택 및 큐, 선형 연결 목록은 모두 선형 구조인 반면 이진 트리는 비선형 구조입니다.

임의의 주소를 가진 일련의 저장 장치를 사용하여 선형 테이블에 데이터 요소를 저장하는 연결된 저장 구조의 선형 테이블입니다. 논리적으로 인접한 요소는 물리적으로 인접할 필요가 없으며 무작위로 액세스할 수 없습니다. 일반적으로 노드별로 설명: 노드(데이터 요소를 나타냄) = 데이터 도메인(데이터 요소의 이미지) + 포인터 도메인(후속 요소의 저장 위치를 ​​나타냄)

체인 저장 구조에서 데이터 구조를 저장하는 저장 공간은 다음과 같습니다. 계속해서, 각 데이터 노드의 저장 순서와 데이터 요소 간의 논리적 관계가 일치하지 않을 수 있으며, 데이터 요소 간의 논리적 관계는 포인터 필드에 의해 결정됩니다. 연쇄 저장 방법은 선형 구조와 비선형 구조를 모두 표현하는 데 사용할 수 있습니다.

일반적으로 선형 리스트의 연결 저장 구조에서는 각 데이터 노드의 저장 기호가 불연속적이고, 저장 공간 내 각 노드의 위치 관계와 논리적 관계도 불일치합니다. 선형 연결 목록의 경우 헤드 포인터에서 시작하여 각 노드의 포인터를 따라 연결 목록의 모든 노드를 검색할 수 있습니다.

선형 연결 리스트를 구축합니다. 이는 링크 포인트를 동적으로 생성하고 이를 차례로 연결 리스트에 연결하는 과정입니다. 선형 연결 리스트의 첫 번째 링크 포인트의 포인터를 리스트로 둡니다.

첫 번째 링크 포인트가 생성되면 연결 리스트가 비어 있으므로 링크 포인트를 리스트에 직접 보내면 됩니다. 데이터 요소를 획득할 때마다 해당 데이터 요소에 대한 링크 포인트가 생성되며, 획득된 데이터 요소의 데이터 정보가 새 노드의 데이터 필드로 전송되는 동안 새 노드의 포인터 필드는 NULL로 설정됩니다. 그런 다음 새 노드의 포인터 필드가 NULL로 설정됩니다. 노드는 연결 목록의 끝에 삽입됩니다.

다음 알고리즘은 선형 연결 목록의 데이터 요소로 data.txt라는 파일에서 문자열을 한 줄씩 읽습니다. 알고리즘은 다음과 같습니다:

LinkList creatList() {
    LinkList r, p, list = NULL;
    char data[ 100 ];
 
    FILE *f = fopen( "data.txt", "rb" );
    while( fgets( data, 100, f ) )
    {
        p = ( LinkList )malloc( sizeof( LNode ) );
        if( p != NULL ){
            strcpy( p->data, data );
            p->link = NULL;
 
            if( list == NULL )
                list = p;
            else
                r->link = p;
            r = p;
        }
    }
    fclose( f );
 
    return list;
}
로그인 후 복사

위 내용은 선형 연결 목록은 선형 목록의 연결 저장 구조입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)