c语言循环链表合并,合并两个带头结点的有序循环链表合并为一个带头结点的有序循环链表...

#include//预编译命令

#includestruct list//定义结构体

{

int num;

list*next;

};

list*head,*end;         //定义全局变量

list*creat()//创建链表的函数

{

list*p=NULL;

list*q=NULL;

head=NULL;

int num;

printf("Input number:\n");

scanf("%d",&num);

while(num!=0)

{

p=new list;      //开辟空间

p->num=num;

if(head==NULL)

head=p;

else

q->next=p;

q=p;

scanf("%d",&num);

}

end=q;   //将链表的结尾最后一个结点赋给end

end->next=head;  //让最后一个结点的的下个结点的地址不为空而指向头指针

return(head);

}

void print(list*head)//打印循环链表的函数

{

int k=0;

list*r=head;

do

{

cout.width(2);

k=k+1;

coutnext;

}while(r!=head);

}

void insert(list*pHead,list*pNode)   //插入接点的函数

{

list*q,*r;

//第一种情况,链表为空

if(pHead==NULL)

{

pHead=pNode;    //链表头指向pNode

return;      //完成插入操作,返回

}

//第二种情况,pNode结点num的值小于链表头结点num的值

//则将pNode的值插到链表头部

if(pNode->num<=pHead->num)

{

pNode->next=pHead;

pHead=pNode;

return;

}

//第三种情况,循环查找正确位置

r=pHead;

q=pHead->next;

while(q!=pHead)

{

if(pNode->num>q->num)

{

r=q;

q=q->next;

}

else

break;

}

r->next=pNode;

pNode->next=q;

}

list*together(list*p1,list*p2)      //定义两个链表合并的函数

{

list*q,*r;

q=p2;

do

{

r=new list;   //开辟空间

r->num=q->num;  //将q的值赋给r

r->next=NULL;       //让r的下一个指针的地址为空,目的是使它成为一个独立的结点

insert(p1,r);  //调用插入结点的函数

q=q->next;   //指针向后拨一个接点

}while(q!=p2);   //当在最后一个结点时停止循环

return(p1);    //返回头指针

}

void main()   //主函数

{

list*list1,*list2;

printf("Input list1\n");

printf("If number is 0,stop inputing\n");

printf("数据请从小到大输入\n");

list1=creat();    //调用创建链表的函数

print(list1);    //打印第一个链表

printf("Input list2\n");

printf("If number is 0,stop inputing\n");

printf("数据请从小到大输入\n");

list2=creat();   //调用创建链表的函数

print(list2);   //打印第二个循环链表

head=together(list1,list2);    //调用合并两个链表的函数

printf("The new list is:\n");

print(head);       //打印最后结果

}

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是用 C 语言创建两个逃增的带头点的有序链表,并从键盘输入链表内容的示例代码: ```c #include <stdio.h> #include <stdlib.h> typedef struct ListNode { int val; struct ListNode *next; } ListNode; // 初始化带头点的链表 ListNode *initList() { ListNode *head = (ListNode*)malloc(sizeof(ListNode)); head->next = NULL; return head; } // 向链表中插入节点 void insert(ListNode *head, int val) { ListNode *p = head; while (p->next && p->next->val < val) { p = p->next; } ListNode *node = (ListNode*)malloc(sizeof(ListNode)); node->val = val; node->next = p->next; p->next = node; } // 遍历链表并输出节点值 void traverse(ListNode *head) { ListNode *p = head->next; while (p) { printf("%d ", p->val); p = p->next; } printf("\n"); } int main() { // 创建 LA 链表 ListNode *head1 = initList(); printf("请输入 LA 链表的节点值(用空格隔开):"); char buf1[1024]; fgets(buf1, 1024, stdin); char *p1 = strtok(buf1, " \n"); while (p1) { int val = atoi(p1); insert(head1, val); p1 = strtok(NULL, " \n"); } // 创建 LB 链表 ListNode *head2 = initList(); printf("请输入 LB 链表的节点值(用空格隔开):"); char buf2[1024]; fgets(buf2, 1024, stdin); char *p2 = strtok(buf2, " \n"); while (p2) { int val = atoi(p2); insert(head2, val); p2 = strtok(NULL, " \n"); } // 遍历 LA 链表 printf("LA 链表的节点值为:"); traverse(head1); // 遍历 LB 链表 printf("LB 链表的节点值为:"); traverse(head2); return 0; } ``` 这里我们定义了一个`ListNode`构体,用于表示链表的节点。然后通过`initList`函数初始化了带头点的链表,通过`insert`函数向链表中插入节点,通过`traverse`函数遍历链表并输出节点的值。最后从键盘输入链表内容,创建两个逃增的带头点的有序链表`LA`和`LB`,并遍历输出它们的节点值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值