Data Structure & Implements 2 - Linked List
04 Nov 2018 | c++ 자료 구조
자료 구조
4. Linked List
4.1 정의
data:image/s3,"s3://crabby-images/8e646/8e646471c82a30b68a4e16f8848d6fac11b8c200" alt="Linked List"
- A Linked List consist of many nodes
- A LINK contains address of (= points to) the next node.
- Address of nodes is not sequential (Address of nodes may change on run time)
- Array와 가장 다른 점
- Size of a linked list is not predefined.
- There is a pointer pointing to the first node of a linked list.
- There is a special address value(=NULL) at the last node
4.2 Array와 Linked List의 차이점
4.2.1 Array
- Sequential representation
- Insert & Delete : Inefficient due to data shift - O(n)
- Size of data must be predefined
- Static storage allocation (during compile time)
4.2.2 Linked List
- **Non-sequential representation
- Insert & Delete : Efficient due to avoiding data shift - O(1)
- Size of data needs not to be predefined
- Dynamic storage allocation (during run time)
4.3 Allocation/Deallocation
- (Memory) Allocation
- Get a currently available node.
- malloc Function
data:image/s3,"s3://crabby-images/e82cf/e82cfbe42ded7b86bb3676e0172e8364b9e57f31" alt="linked list malloc"
- (Memory) Deallocation
- Return a no longer unused node
- free function
data:image/s3,"s3://crabby-images/68a97/68a97c8527b3547c46bc96b162041cd45c55f302" alt="linked list free"
4.4 Mechanisms
4.4.1 Simple Insertion
- To insert ‘eat’ between ‘cat’ and ‘fat’
data:image/s3,"s3://crabby-images/6a5a9/6a5a9f2c1c464c1ab5dec79d83ff793ea384d280" alt="linked list simple insertion1"
- Newly allocate a node by a pointer variable
p
, and stroe ‘eat’ at the node’s DATA
.
- Assign the
LINK
of p
to the node after “cat”, which contains “fat”.
- Assign the
LINK
of the node “cat” to p
.
data:image/s3,"s3://crabby-images/6b4dd/6b4dd240e2c93c1873c0dadfcb40d1855aa85f61" alt="linked list simple insertion2"
4.4.2 Simple Deletion
- To delete ‘fat’ from the list
data:image/s3,"s3://crabby-images/6098d/6098d18bb108e90f1777f9f77005aa2d48ba7ce8" alt="linked list deletion1"
- Assign the
LINK
of ‘fat’ node to the LINK
of ‘cat’ node
- Return (deallocate) the ‘fat’ node by using
free
data:image/s3,"s3://crabby-images/4dc36/4dc365c3293abf1e48593090cc455d20e863286b" alt="linked list deletion2"
4.4.3 Node Definition
- Define the node, named ‘
list_node
’, by using struct
- Each
list_node
consist of two fields, DATA
and LINK
- list_ptr is a pointer type pointing to the next
list_node
- prt is a pointer variable defined on *list_ptr, initially
NULL
data:image/s3,"s3://crabby-images/f5e37/f5e3780284f751b9d537d93914069d032bfd452d" alt="linked list node definition"
4.5 Operators
4.5.1 Basic Operations
- All the variables
p, q, r, ...
are list_ptr type
- Initialize Pointer Value:
p = NULL
- Move to the next node:
p = p -> LINK
data:image/s3,"s3://crabby-images/450e2/450e24023c85ad940cf5fcdf4bf4f12689a827f1" alt="p->LINK"
- Assign Pointer value : Sharing the same node
q = p, q = r, ...
- Compare Pointer Values : only permit
==, !=
if (p == q) then ...
if (p != q) then ...
if (p == NULL) then ...
if (p -> LINK == NULL) then ...
4.5.2 Insert
- To do this, three variables* are required.
ptr
: pointing to the first node in a list
ins
: pointing to the insert position
new
: pointing to the new node
- Two cases are considered
- case 1 : list is empty (i.e.,
ptr
is NULL
)
- case 2 : list is not empty (i.e.,
ptr
)
data:image/s3,"s3://crabby-images/9478f/9478f36254ebf01b21be0c3367d0111cb5f7e347" alt="prt is null?"
data:image/s3,"s3://crabby-images/b99b6/b99b6248ab47cbe1c66e4cfb49c92db683bdac4c" alt="linked list insert"
void Insert (list_ptr *ptr, list_ptr ins) {
list_ptr new;
new = (list_ptr) malloc(sizeof(list_node));
new -> data = 25;
if (*ptr != NULL) { /*In case, list is not empty*/
new -> link = ins -> link;
ins -> link = new;
}
else { /*In case, list becomes empty*/
new -> link = NULL;
*ptr = new;
}
}
data:image/s3,"s3://crabby-images/25c83/25c835198f8dc8976c2b5bbe65ab5e83fa4d9c8a" alt="linked list insert2"
4.5.3 Delete
- To this end, three variables are also required.
ptr
: pointing to the first node in a list
del
: pointing to the delete position
pre
: pointing to the preceding node w.r.t the delte node
- Two cases exist w.r.t the delete position
- case 1 : the fisrt node in a list (i.e., prev is
NULL
)
- case 2 : other nodes except the first node (i.e., ptr in
not NULL
)
data:image/s3,"s3://crabby-images/1d1fa/1d1fadc95c42c2685499afac978e9885d8175062" alt="linked list del"
void Delete(list_ptr *ptr, list_ptr pre, list_ptr del){
if (pre != NULL){
///In case, the delete node is not the first node
pre -> link = del -> link;
}
else{ ///In case, the delete node is the fisrt node
*ptr = (*ptr) -> link;
free(del); ///Deallocate the delete node
}
}
4.5.4 Traverse
data:image/s3,"s3://crabby-images/32bd3/32bd3aa5571cabfcbd0fde2a5020b6c5c5aad2eb" alt="linked list traverse"
자료 구조
4. Linked List
4.1 정의
- A Linked List consist of many nodes
- A LINK contains address of (= points to) the next node.
- Address of nodes is not sequential (Address of nodes may change on run time)
- Array와 가장 다른 점
- Size of a linked list is not predefined.
- There is a pointer pointing to the first node of a linked list.
- There is a special address value(=NULL) at the last node
4.2 Array와 Linked List의 차이점
4.2.1 Array
- Sequential representation
- Insert & Delete : Inefficient due to data shift - O(n)
- Size of data must be predefined
- Static storage allocation (during compile time)
4.2.2 Linked List
- **Non-sequential representation
- Insert & Delete : Efficient due to avoiding data shift - O(1)
- Size of data needs not to be predefined
- Dynamic storage allocation (during run time)
4.3 Allocation/Deallocation
- (Memory) Allocation
- Get a currently available node.
- malloc Function
- (Memory) Deallocation
- Return a no longer unused node
- free function
4.4 Mechanisms
4.4.1 Simple Insertion
- To insert ‘eat’ between ‘cat’ and ‘fat’
- Newly allocate a node by a pointer variable
p
, and stroe ‘eat’ at the node’sDATA
. - Assign the
LINK
ofp
to the node after “cat”, which contains “fat”. - Assign the
LINK
of the node “cat” top
.
4.4.2 Simple Deletion
- To delete ‘fat’ from the list
- Assign the
LINK
of ‘fat’ node to theLINK
of ‘cat’ node - Return (deallocate) the ‘fat’ node by using
free
4.4.3 Node Definition
- Define the node, named ‘
list_node
’, by using struct - Each
list_node
consist of two fields,DATA
andLINK
- list_ptr is a pointer type pointing to the next
list_node
- prt is a pointer variable defined on *list_ptr, initially
NULL
4.5 Operators
4.5.1 Basic Operations
- All the variables
p, q, r, ...
are list_ptr type - Initialize Pointer Value:
p = NULL
- Move to the next node:
p = p -> LINK
- Assign Pointer value : Sharing the same node
q = p, q = r, ...
- Compare Pointer Values : only permit
==, !=
if (p == q) then ...
if (p != q) then ...
if (p == NULL) then ...
if (p -> LINK == NULL) then ...
4.5.2 Insert
- To do this, three variables* are required.
ptr
: pointing to the first node in a listins
: pointing to the insert positionnew
: pointing to the new node
- Two cases are considered
- case 1 : list is empty (i.e.,
ptr
isNULL
) - case 2 : list is not empty (i.e.,
ptr
)
- case 1 : list is empty (i.e.,
void Insert (list_ptr *ptr, list_ptr ins) {
list_ptr new;
new = (list_ptr) malloc(sizeof(list_node));
new -> data = 25;
if (*ptr != NULL) { /*In case, list is not empty*/
new -> link = ins -> link;
ins -> link = new;
}
else { /*In case, list becomes empty*/
new -> link = NULL;
*ptr = new;
}
}
4.5.3 Delete
- To this end, three variables are also required.
ptr
: pointing to the first node in a listdel
: pointing to the delete positionpre
: pointing to the preceding node w.r.t the delte node
- Two cases exist w.r.t the delete position
- case 1 : the fisrt node in a list (i.e., prev is
NULL
) - case 2 : other nodes except the first node (i.e., ptr in
not NULL
)
- case 1 : the fisrt node in a list (i.e., prev is
void Delete(list_ptr *ptr, list_ptr pre, list_ptr del){
if (pre != NULL){
///In case, the delete node is not the first node
pre -> link = del -> link;
}
else{ ///In case, the delete node is the fisrt node
*ptr = (*ptr) -> link;
free(del); ///Deallocate the delete node
}
}
Comments