This series of articles provides a brief introduction to linked lists.
This article, the second in a series, shows you how to insert nodes into a one-way linked list, along with code examples.
1 overview
To insert a node in a one-way linked list, you want to insert the node into the “appropriate” position on the list. Therefore, a prerequisite is required: each node in a one-way linked list is ordered by the value of one of its members (such as students’ grades) (e.g., from small to small). Only when this condition is met can the node insertion operation against the unidirectional linked list be carried out.
To insert a node into a “proper” place in the linked list, two steps are required:
- Find the right place in the list;
- Insert the node into the position found in Step 1.
The algorithm to realize the above two steps is introduced in the form of pseudo-code as follows:
Algorithm: InsertLinkedlist(list,new) Objective: To insert a node into a unidirectional ordered list prerequisite: Linkedlist and node data to be inserted New list {if (list == null) // Insert into empty list {list < -new (*new). Link < -null} else {while ((*new).data > (*cur).data) && ((*cur).link ! = null)) // find location where the new node insert into { pre <- cur cur <- (*cur).link } if ((*new).data <= (*cur).data) { if (list == cur) // insertion at the beginning { list <- new (*new).link <- cur } else // insertion in the middle { (*pre).link <- new (*new).link <- cur } } if ((*cur).link == null) // insertion at the end { (*cur).link <- new (*new).link <- null } } return list }Copy the code
2 Example code and description
Based on the above, you can write sample code to insert a node into a one-way linked list.
The sample code reads as follows:
#include <stdio.h> #define STRUCT_LEN sizeof(struct student) struct student { int stu_num; /* student number */ float stu_score; /* student score */ struct student* next; }; int main() { /* declaration of func */ struct student * insert(struct student * head, struct student * new_node); void print(struct student * list); /* create a static linked list, which sorted by student score from small to large */ struct student * list; struct student stu_1, stu_2, stu_3; stu_1.stu_num = 1; stu_1.stu_score = 88; stu_2.stu_num = 2; stu_2.stu_score = 66; stu_3.stu_num = 3; stu_3.stu_score = 100; list = &stu_2; stu_2.next = &stu_1; stu_1.next = &stu_3; stu_3.next = NULL; /* print linked list before insertion */ printf("before insertion, content of linked list as followed(sorted by student score from small to large):\n"); print(list); /* create new node that wants to insert into linked list */ struct student stu_new; stu_new.stu_num = 5; stu_new.stu_score = 83; /* insert new node into linked list */ list = insert(list, &stu_new); /* print linked list after insertion */ printf("after insertion, content of linked list as followed(sorted by student score from small to large):\n"); print(list); return 0; } /* ** this is the insert linked list function. */ struct student * insert(struct student * head, struct student * new_node) { struct student * cur; struct student * pre; struct student * new; cur = head; /* let cur point first node */ new = new_node; /* let new point the node that wants to insert into linked list */ if (NULL == head) /* insert into empty list */ { head = new; (*new).next = NULL; } while (((*new).stu_score > (*cur).stu_score) && ((*cur).next ! = NULL)) /* find location where the new node insert into */ { pre = cur; cur = (*cur).next; } if ((*new).stu_score <= (*cur).stu_score) { if (head == cur) /* insertion at the beginning */ { head = new; (*new).next = cur; } else /* insertion in the middle */ { (*pre).next = new; (*new).next = cur; } } if ((*cur).next == NULL) /* insertion at the end */ { (*cur).next = new; (*new).next = NULL; } return head; } /* * this is the print linked list content function. */ void print(struct student * list) { struct student *walker; walker = list; printf("The linked list contents(student number and score) as followed:\n"); printf("[student number] [student score]\n"); while (walker ! = NULL) { printf("%d %-f\n", (*walker).stu_num, (*walker).stu_score); walker = (*walker).next; } return; }Copy the code
The compilation and running results of the above code are as follows:
To verify insertion at the head and tail of the list, you can modify the structure member stu_new.stu_score to make the node insert at the head and tail of the list. The compilation and operation of the modified code are as follows:
Description:
- To simplify the code content, the above example code uses a static linked list, that is, all the nodes of the list are defined in the program, and the storage space of the nodes is not created temporarily.
- In the example code above, the linked list is sorted in order of the students’ scores.