用c语言实现两个链表的链接,C语言连接合并两个双向链表程序

创建两个双向链表,并连接这两双向链表中的数据项连接合并成一个双向链接的示例程序,将以下代码保存到一个源文件中:combine_two_doubly_linked_list.c, 如下所示 -

#include

#include

struct node {

int data;

struct node *prev;

struct node *next;

};

struct node *list = NULL;

struct node *list_last = NULL;

struct node *even = NULL;

struct node *even_last = NULL;

struct node *odd = NULL;

struct node *odd_last = NULL;

struct node *current = NULL;

//Create Linked List

void insert(int data) {

// Allocate memory for new node;

struct node *link = (struct node*) malloc(sizeof(struct node));

link->data = data;

link->prev = NULL;

link->next = NULL;

// If head is empty, create new list

if (data % 2 == 0) {

if (even == NULL) {

even = link;

return;

}

else {

current = even;

while (current->next != NULL)

current = current->next;

// Insert link at the end of the list

current->next = link;

even_last = link;

link->prev = current;

}

}

else {

if (odd == NULL) {

odd = link;

return;

}

else {

current = odd;

while (current->next != NULL)

current = current->next;

// Insert link at the end of the list

current->next = link;

odd_last = link;

link->prev = current;

}

}

}

//display the list

void print_backward(struct node *head) {

struct node *ptr = head;

printf("\n[last] <=>");

//start from the beginning

while (ptr != NULL) {

printf(" %d <=>", ptr->data);

ptr = ptr->prev;

}

printf(" [head]\n");

}

//display the list

void printList(struct node *head) {

struct node *ptr = head;

printf("\n[head] <=>");

//start from the beginning

while (ptr != NULL) {

printf(" %d <=>", ptr->data);

ptr = ptr->next;

}

printf(" [last]\n");

}

void combine() {

struct node *link;

list = even;

link = list;

while (link->next != NULL) {

link = link->next;

}

link->next = odd;

odd->prev = link;

// assign link_last to last node of new list

while (link->next != NULL) {

link = link->next;

}

list_last = link;

}

int main() {

int i;

for (i = 1; i <= 10; i++)

insert(i);

printf("Even : ");

printList(even);

printf("Even (R): ");

print_backward(even_last);

printf("Odd : ");

printList(odd);

printf("Odd (R) : ");

print_backward(odd_last);

combine();

printf("Combined List :\n");

printList(list);

printf("Combined List (R):\n");

print_backward(list_last);

return 0;

}

执行上面程序,得到以下结果 -

Even :

[head] <=> 2 <=> 4 <=> 6 <=> 8 <=> 10 <=> [last]

Even (R):

[last] <=> 10 <=> 8 <=> 6 <=> 4 <=> 2 <=> [head]

Odd :

[head] <=> 1 <=> 3 <=> 5 <=> 7 <=> 9 <=> [last]

Odd (R) :

[last] <=> 9 <=> 7 <=> 5 <=> 3 <=> 1 <=> [head]

Combined List :

[head] <=> 2 <=> 4 <=> 6 <=> 8 <=> 10 <=> 1 <=> 3 <=> 5 <=> 7 <=> 9 <=> [last]

Combined List (R):

[last] <=> 9 <=> 7 <=> 5 <=> 3 <=> 1 <=> 10 <=> 8 <=> 6 <=> 4 <=> 2 <=> [head]

¥ 我要打赏

纠错/补充

收藏

加QQ群啦,易百教程官方技术学习群

注意:建议每个人选自己的技术方向加群,同一个QQ最多限加 3 个群。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是用C语言实现两个递增双向链表合并的示例代码: ```c #include <stdio.h> #include <stdlib.h> // 定义链表结构体 typedef struct Node { int data; struct Node* prev; struct Node* next; } Node; // 创建新节点 Node* createNode(int data) { Node* newNode = (Node*)malloc(sizeof(Node)); newNode->data = data; newNode->prev = NULL; newNode->next = NULL; return newNode; } // 合并两个链表 Node* merge(Node* head1, Node* head2) { if (head1 == NULL) return head2; if (head2 == NULL) return head1; Node* mergedHead = NULL; if (head1->data < head2->data) { mergedHead = head1; mergedHead->next = merge(head1->next, head2); } else { mergedHead = head2; mergedHead->next = merge(head1, head2->next); } if (mergedHead->next != NULL) mergedHead->next->prev = mergedHead; return mergedHead; } // 打印链表 void printList(Node* head) { Node* current = head; while (current != NULL) { printf("%d ", current->data); current = current->next; } printf("\n"); } int main() { // 创建第一个链表 Node* head1 = createNode(1); head1->next = createNode(3); head1->next->prev = head1; head1->next->next = createNode(5); head1->next->next->prev = head1->next; printf("List 1: "); printList(head1); // 创建第二个链表 Node* head2 = createNode(2); head2->next = createNode(4); head2->next->prev = head2; head2->next->next = createNode(6); head2->next->next->prev = head2->next; printf("List 2: "); printList(head2); // 合并两个链表 Node* mergedHead = merge(head1, head2); printf("Merged List: "); printList(mergedHead); return 0; } ``` 输出结果: ``` List 1: 1 3 5 List 2: 2 4 6 Merged List: 1 2 3 4 5 6 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值