编写算法,将A表和B表归并成一个按元素值递增有序排列的线性表C,并要求利用原表(即A表和B表的)结点空间存放表C

代码如下(希望对大家有帮助)

#include <iostream>
using namespace std ;
class Node{
	public:
		int data ;
		Node *next ;
};
Node * createNode(int n ){
	Node *head = new Node ;
	Node *pre = head ;
	for(int i = 0 ; i < n ; i++){
		Node *p = new Node ;
		cin>>p->data ;
		pre->next = p ;
		pre = p ;
		p->next = NULL ;
	} 
	return head ; 
}
void display(Node *head){
	Node *p = head->next ;
	while(p != NULL){
		cout<<p->data<<" " ;
		p = p->next ; 
	}
}
Node* add(Node *node1, Node *node2){
    Node*node;
    Node*first , *second , *third ;
    //将合并后的链表存在A表中 
    node= node1;
    first = node1->next ;
    second = node2->next ;
    third = node;
    while(first && second)
    {
        if(first->data< second->data)
        {
            third->next = first; 
            first = first->next;
            third = third->next;
        } 
        else if(first->data == second->data)
        {
            third->next = first ;
            third = third->next ;
            third = second->next ;
			third = third->next ; 
        }
        else
        {
            third->next = second ;
            second = second->next ;
            third = third->next ;
        }
    }
//将多余的接到third上
    third->next=(first ? first : second) ;
    return node;
} 
int main(){
	Node *p = createNode(5) ;
	Node *q = createNode(3) ;  
	display(p) ; 
	cout<<"\n" ;
	display(q) ;
	cout<<"\n" ; 
	display(add(p , q)) ;
	return 0 ;
} 

运行结果:
在这里插入图片描述

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值