zoukankan      html  css  js  c++  java
  • 实现算法2.3的程序

    // algo2-3.cpp 实现算法2.7的程序
    #include"c1.h"
    typedef int ElemType;
    #include"c2-1.h"
    #include"bo2-1.cpp"
    #include"func2-3.cpp" // 包括equal()、comp()、print()、print2()和print1()函数
    void MergeList(SqList La,SqList Lb,SqList &Lc) // 算法2.7
    { // 已知顺序线性表La和Lb的元素按值非递减排列。
    // 归并La和Lb得到新的顺序线性表Lc,Lc的元素也按值非递减排列
    ElemType *pa,*pa_last,*pb,*pb_last,*pc;
    pa=La.elem;
    pb=Lb.elem;
    Lc.listsize=Lc.length=La.length+Lb.length; // 不用InitList()创建空表Lc
    pc=Lc.elem=(ElemType *)malloc(Lc.listsize*sizeof(ElemType));
    if(!Lc.elem) // 存储分配失败
    exit(OVERFLOW);
    pa_last=La.elem+La.length-1;
    pb_last=Lb.elem+Lb.length-1;
    while(pa<=pa_last&&pb<=pb_last) // 表La和表Lb均非空
    { // 归并
    if(*pa<=*pb)
    *pc++=*pa++; // 将pa所指单元的值赋给pc所指单元后,pa和pc分别+1(指向下一个单元)
    else
    *pc++=*pb++; // 将pb所指单元的值赋给pc所指单元后,pa和pc分别+1(指向下一个单元)
    } // 以下两个while循环只会有一个被执行
    while(pa<=pa_last) // 表La非空且表Lb空
    *pc++=*pa++; // 插入La的剩余元素
    while(pb<=pb_last) // 表Lb非空且表La空
    *pc++=*pb++; // 插入Lb的剩余元素
    }
    void main()
    {
    SqList La,Lb,Lc;
    int j;
    InitList(La); // 创建空表La
    for(j=1;j<=5;j++) // 在表La中插入5个元素,依次为1、2、3、4、5
    ListInsert(La,j,j);
    printf("La= "); // 输出表La的内容
    ListTraverse(La,print1);
    InitList(Lb); // 创建空表Lb
    for(j=1;j<=5;j++) // 在表Lb中插入5个元素,依次为2、4、6、8、10
    ListInsert(Lb,j,2*j);
    printf("Lb= "); // 输出表Lb的内容
    ListTraverse(Lb,print1); // 由按非递减排列的表La、Lb得到按非递减排列的表Lc
    MergeList(La,Lb,Lc);
    printf("Lc= "); // 输出表Lc的内容
    ListTraverse(Lc,print1);
    }

    运行结果如下:

    La= 1 2 3 4 5
    Lb= 2 4 6 8 10
    Lc= 1 2 2 3 4 4 5 6 8 10


  • 相关阅读:
    求1000以内的勾股数的算法流程图
    23天的单车旅行,从广州到四川,重庆,大足石刻,母校,家,发完了
    好玩的Flash:跟鼠标拼命
    23天的单车旅行,从广州到四川,息烽集中营,韩国人,乌江,遵义
    如何彻底删除SQL Server2005
    EOF,EOC与感叹号的区别
    如何彻底卸载vs2008及其组件?
    PHP中extract()函数的妙用
    php 函数合并 array_merge 与 + 的区别
    unserialize error at offset
  • 原文地址:https://www.cnblogs.com/KongkOngL/p/4074470.html
Copyright © 2011-2022 走看看