데이터 구조의 각 데이터 요소 간 관계의 복잡성에 따라 데이터 구조는 일반적으로 선형 구조와 비선형 구조라는 두 가지 주요 유형으로 나뉩니다.
선형 연결 목록은 이름에서 알 수 있듯이 체인 목록과 유사합니다. 선형 연결 목록의 반대는 선형 시퀀스 목록입니다. 메모리에서 연속적인 영역을 열어야 하므로 메모리에 저장된 데이터의 상태는 연속적인 반면, 선형 연결 목록의 메모리 저장은 무작위이며 데이터 간의 연결은 포인터에 의존합니다. (추천 학습: 웹 프론트 엔드 비디오 튜토리얼)
비어 있지 않은 데이터 구조가 다음 두 가지 조건을 만족하는 경우:
①루트 노드는 하나만 있고
②각 노드에는 최대 하나의 선행 항목이 있습니다. 또한 최대 하나의 결과가 있습니다. 데이터 구조를 선형 구조라고 하며 선형 테이블이라고도 합니다. 따라서 선형 목록, 스택 및 큐, 선형 연결 목록은 모두 선형 구조인 반면 이진 트리는 비선형 구조입니다.
임의의 주소를 가진 일련의 저장 장치를 사용하여 선형 테이블에 데이터 요소를 저장하는 연결된 저장 구조의 선형 테이블입니다. 논리적으로 인접한 요소는 물리적으로 인접할 필요가 없으며 무작위로 액세스할 수 없습니다. 일반적으로 노드별로 설명: 노드(데이터 요소를 나타냄) = 데이터 도메인(데이터 요소의 이미지) + 포인터 도메인(후속 요소의 저장 위치를 나타냄)
체인 저장 구조에서 데이터 구조를 저장하는 저장 공간은 다음과 같습니다. 계속해서, 각 데이터 노드의 저장 순서와 데이터 요소 간의 논리적 관계가 일치하지 않을 수 있으며, 데이터 요소 간의 논리적 관계는 포인터 필드에 의해 결정됩니다. 연쇄 저장 방법은 선형 구조와 비선형 구조를 모두 표현하는 데 사용할 수 있습니다.
일반적으로 선형 리스트의 연결 저장 구조에서는 각 데이터 노드의 저장 기호가 불연속적이고, 저장 공간 내 각 노드의 위치 관계와 논리적 관계도 불일치합니다. 선형 연결 목록의 경우 헤드 포인터에서 시작하여 각 노드의 포인터를 따라 연결 목록의 모든 노드를 검색할 수 있습니다.
선형 연결 리스트를 구축합니다. 이는 링크 포인트를 동적으로 생성하고 이를 차례로 연결 리스트에 연결하는 과정입니다. 선형 연결 리스트의 첫 번째 링크 포인트의 포인터를 리스트로 둡니다.
첫 번째 링크 포인트가 생성되면 연결 리스트가 비어 있으므로 링크 포인트를 리스트에 직접 보내면 됩니다. 데이터 요소를 획득할 때마다 해당 데이터 요소에 대한 링크 포인트가 생성되며, 획득된 데이터 요소의 데이터 정보가 새 노드의 데이터 필드로 전송되는 동안 새 노드의 포인터 필드는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!