a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C# > 正文

兩路歸并的數(shù)組與鏈表的實現(xiàn)方法

2020-01-24 03:22:34
字體:
供稿:網(wǎng)友

復制代碼 代碼如下:

#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;
}

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美精品一区二区三区在线四季 | 韩国三级中文字幕hd有奶水 | 国产精品成人免费一区二区视频 | 国产99久久精品一区二区永久免费 | 久久亚洲美女视频 | 久久成人精品视频 | 国产精品久久久久国产a级 色999国产 | 国产精品久久久久aaaa九色 | 在线视频97| 亚洲成人久久久 | 国产一区二区不卡 | 久久aⅴ国产欧美74aaa | 日韩精品123| www.色涩涩.com网站 | 成人精品鲁一区一区二区 | 97在线免费 | 日韩中文字幕视频 | 久久久久久久免费 | 国产精品一区二区三 | 国产精品美女久久久久人 | 国产美女高潮一区二区三区 | 国产精品高清在线 | 欧美日韩中文字幕在线 | 人人av在线| 波多野结衣一二三区 | 色综合久久久久 | 午夜噜噜噜 | 在线免费黄色小视频 | 国产精品日韩 | 日韩一区二区在线观看 | 九九热在线视频 | 成人黄色在线观看 | 欧美日韩中文国产一区 | 国产精品白浆 | 国产在线中文字幕 | 伊人99 | 精品一区二区三区免费看 | 欧美激情视频一区二区三区在线播放 | 亚洲婷婷综合网 | 国产精品视频网 | 久久a久久|