воин 2019-04-24 20:25 采纳率: 0%
浏览 1971
已采纳

把两个有序排列的单向整数链表合并成一个有序排列的的整数链表?

从小到大依次输入两列整数,以-1表示结尾,然后根据这两列整数构造两个单向链表,按整数大大小关系把这两个链表合并成一个有序单向链表,最后从头到尾遍历输出这个链表的数据域(用一个空格隔开)。

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-04-24 22:56
    关注
    /*设head1和head2是两个非空单向链表,数据值有重复且升序排序
    将head1和head2合并成一个升序链
    */
    
    #include<stdio.h>
    #include<stdlib.h>
    
    //定义结构体单元 
    typedef struct node{
        int data;//结构体数据域 
        struct node* next;//结构体指针域 
    }ElemSN;
    //逆向创建单向链表(头插法)
    ElemSN *PreCreatLink(int a[],int n)
    {
        ElemSN *head=NULL,*p;
        for(int i=n-1;i>-1;i--)
        {
            p=(ElemSN*)malloc(sizeof(ElemSN));
            p->data=a[i];
            p->next=head;
            head=p;
        }
        return head;
     } 
    
    
     ElemSN* Combine(ElemSN *head1,ElemSN *head2)
     {
        ElemSN *head,*p,*tail;
        head=NULL;
        while(head1&&head2)
        {
            if(head1->data<head2->data)
            {
                p=head1;
                head1=head1->next;
             }
            else
            {
                p=head2;
                head2=head2->next;
            }
            p->next=NULL; 
            if(!head)
            head=tail=p;
            else
            {
                tail=tail->next=p;
            }
         }
         if(head1)
         p=head1;
         else
         p=head2;
         tail->next=p;
         return head;
     }
    
       //打印链表所有结点的值
       void PrintLink(ElemSN* head)
     {
        ElemSN *p=head;
        for(;p;p=p->next)
        printf("%5d",p->data);
     } 
    
    
     int main(void)
     {
        ElemSN *head1,*head2,*head;
        int a[7]={2,3,5,6,7,9,11};
        int b[5]={2,4,5,7,9};
        head1=PreCreatLink(a,7);    //创建链表head1 
        head2=PreCreatLink(b,5);    //创建链表head2 
        head=Combine(head1,head2);  //将两个有序链表合并成一个有序链表 
        PrintLink(head);       //输出链表 
      } 
    
    

    https://blog.csdn.net/vk5176891/article/details/53649225
    https://blog.csdn.net/qq_39241239/article/details/80897992

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?