CHAPTER 41 LISTS All the programs in this file are selected from Ellis Horowitz, Sartaj Sahni, and Susan Anderson-Freed “Fundamentals of Data Structures.

Slides:



Advertisements
Similar presentations
Linked Lists CS-212 Dick Steflik. Linked Lists A sequential collection of information Can be unordered; i.e. in no specific order Can be ordered; may.
Advertisements

Stacks, Queues, and Linked Lists
CSCE 3110 Data Structures & Algorithm Analysis
Chapter 4 Lists Pointers Singly Linked Lists
Chapter 3 – Lists A list is just what the name implies, a finite, ordered sequence of items. Order indicates each item has a position. A list of size 0.
CS Data Structures Chapter 4 Lists. Chain (1/3) Chain: Chain: A singly linked list in which the last node has a null link A singly linked list in.
CSCI2100B Linked List Jeffrey
Senem Kumova Metin Spring2009 STACKS AND QUEUES Chapter 10 in A Book on C.
Data Structures (Second Part) Lecture 3 : Array, Linked List, Stack & Queue Bong-Soo Sohn Assistant Professor School of Computer Science and Engineering.
1 Linked Lists Gordon College Prof. Brinton. 2 Linked List Basics Why use? 1.Efficient insertion or deletion into middle of list. (Arrays are not efficient.
Presented by : Preeti Banswal. What is data structure? A data structure is a way of organizing data that considers not only the items stored, but also.
Chapter 4.
CS Data Structures Chapter 4 Lists. Dynamically Linked Stacks and Queues (1/8)  When several stacks and queues coexisted, there was no efficient.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 12 – Data Structures Outline 12.1Introduction.
CHAPTER 41 LISTS All the programs in this file are selected from Ellis Horowitz, Sartaj Sahni, and Susan Anderson-Freed “Fundamentals of Data Structures.
CS Data Structures Chapter 4 Lists.
Chapter 4 Lists Fundamentals of Data Structures in C Instructors: C. Y. Tang and J. S. Roger Jang All the material are integrated from the textbook "Fundamentals.
Chapter 4 1. Why “linked lists” 2 IndexWord A[0]BAT A[1]CAT A[2]EAT … A[n]WAT Insert “FAT” ? Or delete something.
Chapter 12 Data Structure Associate Prof. Yuh-Shyan Chen Dept. of Computer Science and Information Engineering National Chung-Cheng University.
Dale Roberts Department of Computer and Information Science, School of Science, IUPUI CSCI 240 Abstract Data Types Dale Roberts, Lecturer
UNIT-2. Singly Linked List Doubly Linked List Circular Linked List Representing Stack with Linked List. Representing Queue with Linked List.
Introduction to Data Structure
Linked Lists list elements are stored, in memory, in an arbitrary order explicit information (called a link) is used to go from one element to the next.
Data Structures Week 5 Further Data Structures The story so far  We understand the notion of an abstract data type.  Saw some fundamental operations.
17. ADVANCED USES OF POINTERS. Dynamic Storage Allocation Many programs require dynamic storage allocation: the ability to allocate storage as needed.
CHAPTER 3 Lists, Stacks, and Queues §1 Abstract Data Type (ADT) 【 Definition 】 Data Type = { Objects }  { Operations } 〖 Example 〗 int = { 0,  1, 
Addresses in Memory When a variable is declared, enough memory to hold a value of that type is allocated for it at an unused memory location. This is.
Linked List (Part II). Introduction  Definition of equivalence relation: A relation ≡ over a set S, is said to be an equivalence relation over S iff.
Data Structure in C Transparency No. 4-1 Copyright(c) 1997, Sungkyunkwan University Chapter #4: LISTS Fundamentals of Data Structure in C Horowitz, Sahni.
 Array ◦ sequential representation ◦ some operation can be very time-consuming (data movement) ◦ size of data must be predefined ◦ static storage allocation.
Chapter 4 (cont.) Additional Lists Operations Circular Lists The link field of the last node points to the first node in the list... BATCATFATWAT.
C++ Programming: From Problem Analysis to Program Design, Second Edition Chapter 17: Linked Lists.
Lists Chapter 8. 2 Linked Lists As an ADT, a list is –finite sequence (possibly empty) of elements Operations commonly include: ConstructionAllocate &
Copyright Networking Laboratory Chapter 4. LISTS Horowitz, Sahni, and Anderson-Freed Fundamentals of Data Structures in C, 2nd Edition Computer.
Linked Lists EENG 212 ALGORITHMS And DATA STRUCTURES.
Linked List (Part I). Introduction  Weakness of storing an ordered list in array: Insertion and deletion of arbitrary elements are expensive. ○ Example:
Computer Programming for Engineering Applications ECE 175 Intro to Programming.
Data Structures. Abstract Data Type A collection of related data is known as an abstract data type (ADT) Data Structure = ADT + Collection of functions.
Digital Computer Concept and Practice Copyright ©2012 by Jaejin Lee C Language Part 5.
Dale Roberts Department of Computer and Information Science, School of Science, IUPUI CSCI 240 Elementary Data Structures Linked Lists Linked Lists Dale.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved More Linking.
1 Midterm 1 on Friday February 12 Closed book, closed notes No computer can be used 50 minutes 4 questions Write a function Write program fragment Explain.
CSCE 3110 Data Structures & Algorithm Analysis More on lists. Circular lists. Doubly linked lists.
Linked List Containers. Useful Linked List Add-Ons Are there new variables/changes to the lists as they have been defined that could make our jobs as.
Array 10 GB Hard Disk 2 GB 4 GB2 GB 3 GB DATA 4 GB Free Store data in the form of Array (Continuous memory locations) Solution-1: No Solution. Memory Insufficient.
Dale Roberts Department of Computer and Information Science, School of Science, IUPUI CSCI 230 Dale Roberts, Lecturer Data Structure.
C Tutorial - Pointers CS 537 – Introduction to Operating Systems.
UNIT-II Topics to be covered Singly linked list Circular linked list
LINKED LISTS.
© Oxford University Press All rights reserved. Data Structures Using C, 2e Reema Thareja.
Software Learning Resource Service Platform CHAPTER 4 鏈結串列 (Linked List) 1.
Chapter 12 – Data Structures
Linked List :: Basic Concepts
Lectures linked lists Chapter 6 of textbook
Elementary Data Structures
More Linking Up with Linked Lists
Data Structure Dr. Mohamed Khafagy.
CSCE 3110 Data Structures & Algorithm Analysis
UNIT-3 LINKED LIST.
Data Structures 7th Week
Abstract Data Types Sparse Matrices CSCI 240
Stack and Queue APURBO DATTA.
EEE2108: Programming for Engineers Chapter 4. Linked Lists
CSCE 3110 Data Structures & Algorithm Analysis
ساختمان داده ها به زبان C
Linked List Sudeshna Sarkar.
CSCE 3110 Data Structures & Algorithm Analysis
Linked List (Part I) Data structure.
Chapter 16 Linked Structures
Data Structures Chapter 4: Linked Lists.
Presentation transcript:

CHAPTER 41 LISTS All the programs in this file are selected from Ellis Horowitz, Sartaj Sahni, and Susan Anderson-Freed “Fundamentals of Data Structures in C”, Computer Science Press, 1992.

CHAPTER 42 Introduction n Array successive items locate a fixed distance n disadvantage –data movements during insertion and deletion –waste space in storing n ordered lists of varying size n possible solution –linked list

CHAPTER Pointer Can Be Dangerous pointer int i, *pi; pi = &i;i=10 or *pi=10 pi= malloc(size of(int)); /* assign to pi a pointer to int */ pf=(float *) pi; /* casts an int pointer to a float pointer */

CHAPTER Using Dynamically Allocated Storage int i, *pi; float f, *pf; pi = (int *) malloc(sizeof(int)); pf = (float *) malloc (sizeof(float)); *pi =1024; *pf =3.14; printf(”an integer = %d, a float = %f\n”, *pi, *pf); free(pi); free(pf); *Program4.1:Allocation and deallocation of pointers (p.138) request memory return memory

CHAPTER SINGLY LINKED LISTS bat  cat  sat  vat NULL *Figure 4.1: Usual way to draw a linked list (p.139)

CHAPTER 46 bat  cat  sat  vat NULL *Figure 4.2: Insert mat after cat (p.140) mat  Insertion

CHAPTER 47 bat  cat  sat  vat NULL mat  *Figure 4.3: Delete mat from list (p.140) dangling reference

CHAPTER 48 typedef struct list_node, *list_pointer; typedef struct list_node { char data [4]; list_pointer link; }; Creation list_pointer ptr =NULL; Testing #define IS_EMPTY(ptr) (!(ptr)) Allocation ptr=(list_pointer) malloc (sizeof(list_node)); Example 4.1: create a linked list of words Declaration

CHAPTER 49 b a t \0 NULL  address of first node ptr data ptr link ptr *Figure 4.4:Referencing the fields of a node(p.142) e -> name  (*e).name strcpy(ptr -> data, “bat”); ptr -> link = NULL;

CHAPTER 410 typedef struct list_node *list_pointer; typedef struct list_node { int data; list_pointer link; }; list_pointer ptr =NULL Example 4.2: (p.142) Example: create a two-node list 10  20 NULL ptr

CHAPTER 411 list_pointer create2( ) { /* create a linked list with two nodes */ list_pointer first, second; first = (list_pointer) malloc(sizeof(list_node)); second = ( list_pointer) malloc(sizeof(list_node)); second -> link = NULL; second -> data = 20; first -> data = 10; first ->link = second; return first; } *Program 4.2:Create a tow-node list (p.143) 10  20 NULL ptr

CHAPTER 412 Pointer Review (1) int i, *pi; i pi ?? pi = &i; i pi ?1000 *pi i = 10 or *pi = 10 i pi *pi

CHAPTER 413 Pointer Review (2) typedef struct list_node *list_pointer; typedef struct list_node { int data; list_pointer link; } list_pointer ptr = NULL; ptr 1000 NULL ptr = malloc(sizeof(list_node)); ptr *ptr ptr->data  (*ptr).data data link

CHAPTER 414 Pointer Review (3) void delete(list_pointer *ptr, list_pointer trail, list_pinter node) ptr: a pointer point to a pointer point to a list node ptr *ptr(*ptr)->link trail (node): a pointer point to a list node trail *trail data link trail->link  (*trail).link

CHAPTER 415 Pointer Review (4) element delete(stack_pointer *top) top delete(&st) vs. delete(st) top st st top 400 Does not change.

CHAPTER 416 void insert(list_pointer *ptr, list_pointer node) { /* insert a new node with data = 50 into the list ptr after node */ list_pointer temp; temp = (list_pointer) malloc(sizeof(list_node)); if (IS_FULL(temp)){ fprintf(stderr, “The memory is full\n”); exit (1); } List Insertion: Insert a node after a specific node

CHAPTER 417 temp->data = 50; if (*ptr) { noempty list temp->link =node ->link; node->link = temp; } else { empty list temp->link = NULL; *ptr =temp; } } *Program 4.3:Simple insert into front of list (p.144) 50  10  20 NULL temp ptr node

CHAPTER  20 NULL 50  20 NULL 50  ptr node trail = NULL ptr (a) before deletion (b)after deletion *Figure 4.7: List after the function call Delete(&ptr,NULL.ptr);(p.145)

CHAPTER  20 NULL 50  20 NULL 50  (a) before deletion (b)after deletion Delete node other than the first node. ptr trail node ptr List Deletion Delete the first node. 10  20 NULL 50  20 NULL 10  ptr trail node ptr

CHAPTER 420 void delete(list_pointer *ptr, list_pointer trail, list_pointer node) { /* delete node from the list, trail is the preceding node ptr is the head of the list */ if (trail) trail->link = node->link; else *ptr = (*ptr) ->link; free(node); } 10  20 NULL 50  20 NULL 10  trail node 10  20 NULL 50  20 NULL 50  ptr node ptr

CHAPTER 421 void print_list(list_pointer ptr) { printf(“The list ocntains: “); for ( ; ptr; ptr = ptr->link) printf(“%4d”, ptr->data); printf(“\n”); } *Program 4.5: Printing a list (p.146) Print out a list (traverse a list)

CHAPTER DYNAMICALLY LINKED STACKS AND QUEUES   NULL    top element link (a) Linked Stack   NULL    front element link (b) Linked queue rear *Figure 4.10: Linked Stack and queue (p.147)

CHAPTER 423 #define MAX_STACKS 10 /* maximum number of stacks */ typedef struct { int key; /* other fields */ } element; typedef struct stack *stack_pointer; typedef struct stack { element item; stack_pointer link; }; stack_pointer top[MAX_STACKS]; Represent n stacks

CHAPTER 424 #define MAX_QUEUES 10 /* maximum number of queues */ typedef struct queue *queue_pointer; typedef struct queue { element item; queue_pointer link; }; queue_pointer front[MAX_QUEUE], rear[MAX_QUEUES]; Represent n queues

CHAPTER 425 void add(stack_pointer *top, element item) { /* add an element to the top of the stack */ stack_pointer temp = (stack_pointer) malloc (sizeof (stack)); if (IS_FULL(temp)) { fprintf(stderr, “ The memory is full\n”); exit(1); } temp->item = item; temp->link = *top; *top= temp; * Program 4.6:Add to a linked stack (p.149) } Push in the linked stack

CHAPTER 426 element delete(stack_pointer *top) { /* delete an element from the stack */ stack_pointer temp = *top; element item; if (IS_EMPTY(temp)) { fprintf(stderr, “The stack is empty\n”); exit(1); } item = temp->item; *top = temp->link; free(temp); return item; } *Program 4.7: Delete from a linked stack (p.149) pop from the linked stack

CHAPTER 427 enqueue in the linked queue void addq(queue_pointer *front, queue_pointer *rear, element item) { /* add an element to the rear of the queue */ queue_pointer temp = (queue_pointer) malloc(sizeof (queue)); if (IS_FULL(temp)) { fprintf(stderr, “ The memory is full\n”); exit(1); } temp->item = item; temp->link = NULL; if (*front) (*rear) -> link = temp; else *front = temp; *rear = temp; }

CHAPTER 428 dequeue from the linked queue (similar to push) element deleteq(queue_pointer *front) { /* delete an element from the queue */ queue_pointer temp = *front; element item; if (IS_EMPTY(*front)) { fprintf(stderr, “The queue is empty\n”); exit(1); } item = temp->item; *front = temp->link; free(temp); return item; }

CHAPTER 429 Polynomials typedef struct poly_node *poly_pointer; typedef struct poly_node { int coef; int expon; poly_pointer link; }; poly_pointer a, b, c; coef expon link Representation

CHAPTER 430 Examples a b null

CHAPTER 431 Adding Polynomials a b d a->expon == b->expon a b d a->expon expon -3 10

CHAPTER 432 Adding Polynomials (Continued) a b a->expon > b->expon d 2 8

CHAPTER 433 Alogrithm for Adding Polynomials poly_pointer padd(poly_pointer a, poly_pointer b) { poly_pointer front, rear, temp; int sum; rear =(poly_pointer)malloc(sizeof(poly_node)); if (IS_FULL(rear)) { fprintf(stderr, “The memory is full\n”); exit(1); } front = rear; while (a && b) { switch (COMPARE(a->expon, b->expon)) {

CHAPTER 434 case -1: /* a->expon expon */ attach(b->coef, b->expon, &rear); b= b->link; break; case 0: /* a->expon == b->expon */ sum = a->coef + b->coef; if (sum) attach(sum,a->expon,&rear); a = a->link; b = b->link; break; case 1: /* a->expon > b->expon */ attach(a->coef, a->expon, &rear); a = a->link; } for (; a; a = a->link) attach(a->coef, a->expon, &rear); for (; b; b=b->link) attach(b->coef, b->expon, &rear); rear->link = NULL; temp = front; front = front->link; free(temp); return front; } Delete extra initial node.

CHAPTER 435 Analysis (1)coefficient additions 0  additions  min(m, n) where m (n) denotes the number of terms in A (B). (2)exponent comparisons extreme case e m-1 > f m-1 > e m-2 > f m-2 > … > e 0 > f 0 m+n-1 comparisons (3)creation of new nodes extreme case m + n new nodes summaryO(m+n)

CHAPTER 436 Attach a Term void attach(float coefficient, int exponent, poly_pointer *ptr) { /* create a new node attaching to the node pointed to by ptr. ptr is updated to point to this new node. */ poly_pointer temp; temp = (poly_pointer) malloc(sizeof(poly_node)); if (IS_FULL(temp)) { fprintf(stderr, “The memory is full\n”); exit(1); } temp->coef = coefficient; temp->expon = exponent; (*ptr)->link = temp; *ptr = temp; }

CHAPTER 437 A Suite for Polynomials poly_pointer a, b, d, e;... a = read_poly(); b = read_poly(); d = read_poly(); temp = pmult(a, b); e = padd(temp, d); print_poly(e); read_poly() print_poly() padd() psub() pmult() temp is used to hold a partial result.By returning the nodes of temp, wemay use it to hold other polynomials e(x) = a(x) * b(x) + d(x)

CHAPTER 438 Erase Polynomials void earse(poly_pointer *ptr) { /* erase the polynomial pointed to by ptr */ poly_pointer temp; while (*ptr) { temp = *ptr; *ptr = (*ptr)->link; free(temp); } O(n)

CHAPTER 439 Circularly Linked Lists ptr avail... avail temp circular list vs. chain

CHAPTER 440 Maintain an Available List poly_pointer get_node(void) { poly_pointer node; if (avail) { node = avail; avail = avail->link: } else { node = (poly_pointer)malloc(sizeof(poly_node)); if (IS_FULL(node)) { printf(stderr, “The memory is full\n”); exit(1); } return node; }

CHAPTER 441 Maintain an Available List (Continued) void ret_node(poly_pointer ptr) { ptr->link = avail; avail = ptr; } void cerase(poly_pointer *ptr) { poly_pointer temp; if (*ptr) { temp = (*ptr)->link; (*ptr)->link = avail; avail = temp; *ptr = NULL; } Insert ptr to the front of this list (1) (2) Erase a circular list (see next page) Independent of # of nodes in a list O(1) constant time

CHAPTER Representing Polynomials As Circularly Linked Lists      avail temp ptr     NULL avail *Figure 4.14: Returning a circular list to the avail list (p.159) (1) (2)

CHAPTER 443 Head Node a a Zero polynomial Represent polynomial as circular list. (1) zero (2) others

CHAPTER 444 Another Padd poly_pointer cpadd(poly_pointer a, poly_pointer b) { poly_pointer starta, d, lastd; int sum, done = FALSE; starta = a; a = a->link; b = b->link; d = get_node(); d->expon = -1; lastd = d; do { switch (COMPARE(a->expon, b->expon)) { case -1: attach(b->coef, b->expon, &lastd); b = b->link; break; Set expon field of head node to -1.

CHAPTER 445 Another Padd (Continued) case 0: if (starta == a) done = TRUE; else { sum = a->coef + b->coef; if (sum) attach(sum,a->expon,&lastd); a = a->link; b = b->link; } break; case 1: attach(a->coef,a->expon,&lastd); a = a->link; } } while (!done); lastd->link = d; return d; } Link last node to first

CHAPTER 446 Additional List Operations typedef struct list_node *list_pointer; typedef struct list_node { char data; list_pointer link; }; Invert single linked lists Concatenate two linked lists

CHAPTER 447 Invert Single Linked Lists list_pointer invert(list_pointer lead) { list_pointer middle, trail; middle = NULL; while (lead) { trail = middle; middle = lead; lead = lead->link; middle->link = trail; } return middle; } 0: null 1: lead  2: lead... Use two extra pointers: middle and trail.

CHAPTER 448 Concatenate Two Lists list_pointer concatenate(list_pointer ptr1, list_pointer ptr2) { list_pointer temp; if (IS_EMPTY(ptr1)) return ptr2; else { if (!IS_EMPTY(ptr2)) { for (temp=ptr1;temp->link;temp=temp->link); temp->link = ptr2; } return ptr1; } O(m) where m is # of elements in the first list

CHAPTER Operations For Circularly Linked List X 1  X 2  X 3  a *Figure 4.16: Example circular list (p.165) What happens when we insert a node to the front of a circular linked list? Problem: move down the whole list.

CHAPTER 450 X 1  X 2  X 3  a *Figure 4.17: Pointing to the last node of a circular list (p.165) A possible solution: Note a pointer points to the last node.

CHAPTER 451 Operations for Circular Linked Lists void insert_front (list_pointer *ptr, list_pointer node) { if (IS_EMPTY(*ptr)) { *ptr= node; node->link = node; } else { node->link = (*ptr)->link; (1) (*ptr)->link = node; (2) } X 1  X 2  X 3  (1) (2) ptr

CHAPTER 452 Length of Linked List int length(list_pointer ptr) { list_pointer temp; int count = 0; if (ptr) { temp = ptr; do { count++; temp = temp->link; } while (temp!=ptr); } return count; }

CHAPTER 453 Equivalence Relations A relation over a set, S, is said to be an equivalence relation over S iff it is symmertric, reflexive, and transitive over S. reflexive, x=x symmetric, if x=y, then y=x transitive, if x=y and y=z, then x=z

CHAPTER 454 Examples 0=4, 3=1, 6=10, 8=9, 7=4, 6=8, 3=5, 2=11, 11=1 three equivalent classes {0,2,4,7,11}; {1,3,5}; {6,8,9,10}

CHAPTER 455 A Rough Algorithm to Find Equivalence Classes void equivalenec() { initialize; while (there are more pairs) { read the next pair ; process this pair; } initialize the output; do { output a new equivalence class; } while (not done); } What kinds of data structures are adopted? Phase 1 Phase 2

CHAPTER 456 First Refinement #include #define MAX_SIZE 24 #define IS_FULL(ptr) (!(ptr)) #define FALSE 0 #define TRUE 1 void equivalence() { initialize seq to NULL and out to TRUE while (there are more pairs) { read the next pair, ; put j on the seq[i] list; put i on the seq[j] list; } for (i=0; i<n; i++) if (out[i]) { out[i]= FALSE; output this equivalence class; } direct equivalence Compute indirect equivalence using transitivity

CHAPTER 457 Lists After Pairs are input [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] seq NULL typedef struct node *node_pointer ; typedef struct node { int data; node_pointer link; }; 0  4 3  1 6  10 8  9 7  4 6  8 3  5 2  

CHAPTER 458 Final Version for Finding Equivalence Classes void main(void) { short int out[MAX_SIZE]; node_pointer seq[MAX_SIZE]; node_pointer x, y, top; int i, j, n; printf(“Enter the size (<= %d) “, MAX_SIZE); scanf(“%d”, &n); for (i=0; i<n; i++) { out[i]= TRUE; seq[i]= NULL; } printf(“Enter a pair of numbers (-1 -1 to quit): “); scanf(“%d%d”, &i, &j); Phase 1: input the equivalence pairs:

CHAPTER 459 while (i>=0) { x = (node_pointer) malloc(sizeof(node)); if (IS_FULL(x)) fprintf(stderr, “memory is full\n”); exit(1); } x->data= j; x->link= seq[i]; seq[i]= x; if (IS_FULL(x)) fprintf(stderr, “memory is full\n”); exit(1); } x->data= i; x->link= seq[j]; seq[j]= x; printf(“Enter a pair of numbers (-1 -1 to \ quit): “); scanf(“%d%d”, &i, &j); } Insert x to the top of lists seq[i] Insert x to the top of lists seq[j]

CHAPTER 460 for (i=0; i<n; i++) { if (out[i]) { printf(“\nNew class: %5d”, i); out[i]= FALSE; x = seq[i]; top = NULL; for (;;) { while (x) { j = x->data; if (out[j]) { printf(“%5d”, j); out[j] = FALSE; y = x->link; x->link = top; top = x; x = y; } else x = x->link; } if (!top) break; x = seq[top->data]; top = top->link; } Phase 2: output the equivalence classes push pop

CHAPTER Sparse Matrices inadequates of sequential schemes (1) # of nonzero terms will vary after some matrix computation (2) matrix just represents intermediate results new scheme Each column (row): a circular linked list with a head node

CHAPTER 462 Revisit Sparse Matrices down head right next head node down entry right value rowcol entry a ij i j entry node a ij # of head nodes = max{# of rows, # of columns} 連同一列元素

CHAPTER 463 Linked Representation for Matrix Circular linked list

CHAPTER 464 #define MAX_SIZE 50 /* size of largest matrix */ typedef enum {head, entry} tagfield; typedef struct matrix_node *matrix_pointer; typedef struct entry_node { int row; int col; int value; }; typedef struct matrix_node { matrix_pointer down; matrix_pointer right; tagfield tag;

CHAPTER 465 union { matrix_pointer next; entry_node entry; } u; }; matrix_pointer hdnode[MAX_SIZE];

CHAPTER 466 *Figure 4.22: Sample input for sparse matrix (p.174)

CHAPTER 467 Read in a Matrix matrix_pointer mread(void) { /* read in a matrix and set up its linked list. An global array hdnode is used */ int num_rows, num_cols, num_terms; int num_heads, i; int row, col, value, current_row; matrix_pointer temp, last, node; printf(“Enter the number of rows, columns and number of nonzero terms: “);

CHAPTER 468 scanf(“%d%d%d”, &num_rows, &num_cols, &num_terms); num_heads = (num_cols>num_rows)? num_cols : num_rows; /* set up head node for the list of head nodes */ node = new_node(); node->tag = entry; node->u.entry.row = num_rows; node->u.entry.col = num_cols; if (!num_heads) node->right = node; else { /* initialize the head nodes */ for (i=0; i<num_heads; i++) { term= new_node(); hdnode[i] = temp; hdnode[i]->tag = head; hdnode[i]->right = temp; hdnode[i]->u.next = temp; } O(max(n,m))

CHAPTER 469 current_row= 0; last= hdnode[0]; for (i=0; i<num_terms; i++) { printf(“Enter row, column and value:”); scanf(“%d%d%d”, &row, &col, &value); if (row>current_row) { last->right= hdnode[current_row]; current_row= row; last=hdnode[row]; } temp = new_node(); temp->tag=entry; temp->u.entry.row=row; temp->u.entry.col = col; temp->u.entry.value = value; last->right = temp;/*link to row list */ last= temp; /* link to column list */ hdnode[col]->u.next->down = temp; hdnode[col]=>u.next = temp; }... 利用 next field 存放 column 的 last node

CHAPTER 470 /*close last row */ last->right = hdnode[current_row]; /* close all column lists */ for (i=0; i<num_cols; i++) hdnode[i]->u.next->down = hdnode[i]; /* link all head nodes together */ for (i=0; i<num_heads-1; i++) hdnode[i]->u.next = hdnode[i+1]; hdnode[num_heads-1]->u.next= node; node->right = hdnode[0]; } return node; } O(max{#_rows, #_cols}+#_terms)

CHAPTER 471 Write out a Matrix void mwrite(matrix_pointer node) { /* print out the matrix in row major form */ int i; matrix_pointer temp, head = node->right; printf(“\n num_rows = %d, num_cols= %d\n”, node->u.entry.row,node->u.entry.col); printf(“The matrix by row, column, and value:\n\n”); for (i=0; i u.entry.row; i++) { for (temp=head->right;temp!=head;temp=temp->right) printf(“%5d%5d%5d\n”, temp->u.entry.row, temp->u.entry.col, temp->u.entry.value); head= head->u.next; /* next row */ } O(#_rows+#_terms)

CHAPTER 472 Erase a Matrix void merase(matrix_pointer *node) { int i, num_heads; matrix_pointer x, y, head = (*node)->right; for (i=0; i u.entry.row; i++) { y=head->right; while (y!=head) { x = y; y = y->right; free(x); } x= head; head= head->u.next; free(x); } y = head; while (y!=*node) { x = y; y = y->u.next; free(x); } free(*node); *node = NULL; } Free the entry and head nodes by row. O(#_rows+#_cols+#_terms) Alternative: 利用 Fig 4.14 的技巧,把一列資料 erase (constant time)

CHAPTER 473 Doubly Linked List Move in forward and backward direction. Singly linked list (in one direction only) How to get the preceding node during deletion or insertion? Using 2 pointers Node in doubly linked list left link field (llink) data field (item) right link field (rlink)

CHAPTER 474 Doubly Linked Lists typedef struct node *node_pointer; typedef struct node { node_pointer llink; element item; node_pointer rlink; } head node llink item rlink ptr = ptr->rlink->llink = ptr->llink->rlink

CHAPTER 475 ptr *Figure 4.24:Empty doubly linked circular list with head node (p.180)

CHAPTER 476  node newnode node *Figure 4.25: Insertion into an empty doubly linked circular list (p.181)

CHAPTER 477 Insert void dinsert(node_pointer node, node_pointer newnode) { (1) newnode->llink = node; (2) newnode->rlink = node->rlink; (3) node->rlink->llink = newnode; (4) node->rlink = newnode; } head node llink item rlink (2) (4) (1) (3)

CHAPTER 478 Delete void ddelete(node_pointer node, node_pointer deleted) { if (node==deleted) printf(“Deletion of head node not permitted.\n”); else { (1) deleted->llink->rlink= deleted->rlink; (2) deleted->rlink->llink= deleted->llink; free(deleted); } head node llink item rlink (1) (2)