两路归并的数组与链表的实现方法

时间:2021-10-28 04:32:15 


#include<iostream>
#include<assert.h>
using namespace std;
struct node
{
    int val;
    node * next;
    node(int v)
    {
        val=v;
        next=NULL;
    }
};

node * merge(node* list1 , node * list2)
{
    assert(list1!=NULL&&list2!=NULL);
    node * res;
    if(list1->val<=list2->val)
    {
        res=list1;
        list1=list1->next;
    }
    else
    {
        res=list2;
        list2=list2->next;
    }
    node * p = res;
    node *p1 =list1,*p2 =list2;

    while(p1!=NULL&&p2!=NULL)
    {
        if(p1->val<=p2->val)
        {
            p->next=p1;
            p=p->next;
            p1=p1->next;
        }
        else
        {
            p->next=p2;
            p=p->next;
            p2=p2->next;
        }
    }

    while(p1!=NULL)
    {
        p->next=p1;
        p=p->next;
        p1=p1->next;
    }
    while(p2!=NULL)
    {
        p->next=p2;
        p=p->next;
        p2=p2->next;
    }
    return res;
}

int * merge(int * arr1,int la, int * arr2,int lb)
{
    int i=0,j=0;
    int * arr = new int[la+lb];
    int t=0;
    while(i<la&&j<lb)
    {
        if(arr1[i]<=arr2[j])
        {
            arr[t++]=arr1[i];
            i++;
        }
        else
        {
            arr[t++]=arr2[j];
            j++;
        }
    }
    while(i<la)
    {
        arr[t++]=arr1[i];
        i++;
    }
    while(j<lb)
    {
        arr[t++]=arr2[j];
        j++;
    }
    return arr;
}

void setLinkData(node * & list1 , node * & list2)
{
    node * node1 = new node(2);
    node * node2 = new node(3);
    node * node3 = new node(7);
    node * node4= new node(9);
    node1->next=node2;
    node2->next=node3;
    node3->next=node4;
    list1=node1;

    node * node5 = new node(1);
    node * node6 = new node(4);
    node * node7 = new node(6);
    node * node8 = new node(8);
    node5->next=node6;
    node6->next=node7;
    node7->next=node8;
    list2=node5;
}

int main()
{
    node * list1;
    node * list2;
    setLinkData(list1,list2);
    int arr1[]={1,6,15,17,19};
    int arr2[]={2,4,6,8,10};
    int * arr = merge(arr1,5,arr2,5);
    node * ans = merge(list1,list2);
    //Print result
    int length=10;
    for(int i=0;i<10;i++)
    {
        cout<<*arr<<endl;
        arr++;
    }
    while(ans!=NULL)
    {
        cout<<ans->val<<endl;
        ans=ans->next;
    }
    return 0;
}

标签:链表,数组
0
投稿

猜你喜欢

  • java获取文件的inode标识符的方法

    2021-06-19 15:10:49
  • C#使用is、as关键字以及显式强转实现引用类型转换

    2023-01-29 16:15:27
  • Hashmap非线程安全关于hash值冲突处理

    2023-11-11 09:22:10
  • Java程序中实现调用Python脚本的方法详解

    2021-07-08 22:00:08
  • 完美解决java读取大文件内存溢出的问题

    2023-07-31 17:53:17
  • Android实现移动小球和CircularReveal页面切换动画实例代码

    2023-03-03 03:45:50
  • myeclipse安装Spring Tool Suite(STS)插件的方法步骤

    2023-02-22 00:56:02
  • C# 通过ServiceStack 操作Redis

    2023-12-13 06:18:01
  • Java实现简单台球游戏

    2022-06-28 23:55:59
  • 示例解析java面向对象编程封装与访问控制

    2021-10-18 19:55:19
  • 利用Java写一个学生管理系统

    2023-09-24 17:06:54
  • Java实现石头剪刀布小游戏

    2023-02-25 22:41:29
  • Android开发RecyclerView实现折线图效果

    2022-08-27 12:59:34
  • spring boot 打包jar jar没有主目录清单问题的完美解决方法

    2021-08-28 16:07:39
  • Springboot通过谷歌Kaptcha 组件生成图形验证码功能

    2021-07-24 23:42:47
  • MyBatis通用Mapper和PageHelper的过程详解

    2022-09-29 16:17:03
  • c#基础知识---委托,匿名函数,lambda

    2023-06-12 18:18:07
  • Java反射概念与使用实例代码

    2022-02-24 23:55:40
  • 微信小程序微信登录的实现方法详解(JAVA后台)

    2023-08-29 12:37:25
  • 在Unity中捕捉Android的常用按钮返回事件

    2023-01-31 00:11:36
  • asp之家 软件编程 m.aspxhome.com