链表的有序合并

 


#include <stdio.h>
#include <stdarg.h>
#include <assert.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>

typedef struct node
{
    int iData;
    struct node* next;

}Node;

typedef struct list
{
    int ilen;
    Node* pFrist;

}List;

//创建节点

Node* mknode()
{

    Node* node =(Node*)malloc(sizeof(Node));
    if(NULL == node)
    {
        fprintf(stdout,"malloc error\n");
        exit(EXIT_FAILURE);
    }
    memset(node,0,sizeof(Node));
    return node;
}
//创建头节点
List* mklist()
{
   List* list = (List*)malloc(sizeof(List));
   if(NULL == list)
   {
       fprintf(stdout,"malloc list error\n");
       exit(EXIT_FAILURE);

   }
   memset(list,0,sizeof(List));
   return list;

}


//插入数据
void insert(List *list,int data)
{
    if(NULL == list)
    {

        return;
    }
    Node* node = mknode();
    node->iData = data;
    if(NULL == list->pFrist)
    {
        list->pFrist = node;
    }
    else
    {
        Node *pre = list->pFrist;
        Node *cur = pre;
        while(cur!=NULL)
        {
           if(data < cur->iData)
           {
               if(cur == list->pFrist)
               {
                   node->next=cur;
                   list->pFrist=node;

               }else
               {
                   pre->next=node;
                   node->next = cur;

               }
               break;
           }
           pre = cur;
           cur = cur->next;

        }
    if(cur == NULL)
    {
        pre->next=node;

    }

    }

}
//打印数据
void display(const List *list)
{
    if(NULL == list->pFrist)
    {
        printf("list is empty\n");
        return ;
    }
    Node* cur = list->pFrist;
    while(cur!=NULL)
    {
        printf("%d ",cur->iData);
                cur= cur->next;

    }

    printf("\n");

}
//创建链表
List *getlist()
{
    List *list = mklist();
    int iData = 0;
    while(1)
    {
        printf("please input data:\n");
        scanf("%d",&iData);
        if(0 == iData)
        {
            break;

        }
        insert(list,iData);
        display(list);


    }

    return list;
}
//链表合并
void merge(List* dest,List* src)
{
    if(NULL == dest|| NULL ==src)
    {
        return ;

    }
    Node* dCurNode =dest->pFrist;
    Node* dPreNode = dCurNode;
    Node* sNode = src->pFrist;

    while(NULL !=sNode )  //判断资源是否为空
    {
        while(NULL!= dCurNode)  //判断目标是否为空
        {
            if(sNode->iData < dCurNode->iData)
            {
                src->pFrist=sNode->next;//取出第一个节点
                if(dCurNode==dest->pFrist) //判断是不是第一个节点
                {
                    dest->pFrist=sNode;
                    sNode->next=dCurNode;

                }else                                     //中间插入
                {
                    dPreNode->next = sNode;
                    sNode->next = dCurNode;
                }
                dPreNode = sNode; //改变指针指向
                break;                           //跳出循环获得下一个 要查入的节点
            }
            else
            {

                dPreNode=dCurNode;                 //如果移动指针查找第一个比sNode 大的节点
                dCurNode = dCurNode->next;
            }

        }                                           //跳出循环
        if(NULL == dCurNode && NULL != sNode)
        {

            if(NULL == dest->pFrist)   //待查入的list为空
            {
                dest->pFrist = sNode;
                src->pFrist = NULL;

            }else   //目标list的当前指针为空 把目标list直接插入尾部
            {
                dPreNode->next = sNode;
                src->pFrist = NULL;
            }
            break;
        }
        sNode =src->pFrist; //改变目标list指针
    }
}


int main()
{
    printf("******list1*******\n");
    List *l1 = getlist();


    printf("******list2******\n");
    List *l2 = getlist();

    merge(l1,l2);
    printf("\n\n******list 1******\n");
    display(l1);
    printf("\n\n******lsit********\n");
    display(l2);

    return 0;
}






posted @ 2019-05-27 19:07  countryboy666  阅读(125)  评论(0编辑  收藏  举报