设A和B是两个单链表,其表中元素递增有序,使用一算法将A和B归并成一个案元素递减有序的单链表C(该程序中的功能包含了上几个博客中的部分功能)

//头文件
#ifndef LIST_H
#define LIST_H

#include
   
   
    
    
#include
    
    
     
     
using namespace std;
template
     
     
      
      
class LinkNode{
public:
	T data;
	LinkNode
      
      
       
       * link;
	LinkNode()
	{

	}
	LinkNode(const T& item,LinkNode
       
       
         *ptr=NULL){ data = item; link = ptr; } }; template 
        
          class List{ private: LinkNode 
         
           * head; LinkNode 
          
            * currPos; public: List(); ~List(); void Append(const T value);//为链表赋值,规定链表长度 void clear(); void print(); void HeadToTail();//将链表倒置 //最大值,节点数,平均值 T MaxValue(); int Count(); T Average(); //合并链表 void AppendIncre(const T value); void Merge(List 
           
             & ptr);//合并两个已排序的链表 }; template 
            
              void List 
             
               ::AppendIncre(const T value) { if (head == NULL) { head = new LinkNode 
              
                (value); currPos = head; } else { LinkNode 
               
                 * p = currPos; if (value < (p->data)) { return ; } p->link = new LinkNode 
                
                  (value); p = p->link; p->link = NULL; currPos = p; } } template 
                 
                   void List 
                  
                    ::Merge(List 
                   
                     & ptr) { LinkNode 
                    
                      * pa = head; LinkNode 
                     
                       * pb = ptr.head; //由于链表不带头结点,所以先比较第一个数据的大小,从而确定合并后的链表的头指针的位置 LinkNode 
                      
                        * pd = (pa->data >= pb->data) ? pa : pb; LinkNode 
                       
                         * p = new LinkNode 
                        
                          (pd->data); LinkNode 
                         
                           * pHead = p; if (p-&g
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值