第三周项目二 建设”顺序表“算法库

<pre name="code" class="cpp">/*  
* Copyright (c)2016,烟台大学计算机与控制工程学院  
* All rights reserved.  
* 文件名称:项目2.cpp  
* 作    者:高金艳  
* 完成日期:2016年9月14日  
* 版 本 号:v1.0   
*问题描述:请采用程序的多文件组织形式,在项目1的基础上,建立  
           如上的两个文件,另外再建立一个源文件,编制main函  
           数,完成相关的测试工作。    
*输入描述:无    
*程序输出:依据各个函数而定   
*/    


 
头文件list.h:

#define MaxSize 50    
#include <stdio.h>    
#include <malloc.h>    
typedef int ElemType;    
typedef struct    
{    
    ElemType data[MaxSize];    
    int length;    
} SqList;    
void CreateList(SqList *&L, ElemType a[], int n);//用数组创建线性表    
void InitList(SqList *&L);//初始化线性表InitList(L)    
void DestroyList(SqList *&L);//销毁线性表DestroyList(L)    
bool ListEmpty(SqList *L);//判定是否为空表ListEmpty(L)    
int ListLength(SqList *L);//求线性表的长度ListLength(L)    
void DispList(SqList *L);//输出线性表DispList(L)    
bool GetElem(SqList *L,int i,ElemType &e);//求某个数据元素值GetElem(L,i,e)    
int LocateElem(SqList *L, ElemType e);//按元素值查找LocateElem(L,e)    
bool ListInsert(SqList *&L,int i,ElemType e);//插入数据元素ListInsert(L,i,e)    
bool ListDelete(SqList *&L,int i,ElemType &e);//删除数据元素ListDelete(L,i,e)#endif // LIST_H_INCLUDED    

源文件list.cpp
#include "list.h"    
    
//用数组创建线性表    
void CreateList(SqList *&L, ElemType a[], int n)    
{    
    int i;    
    L=(SqList *)malloc(sizeof(SqList));    
    for (i=0; i<n; i++)    
        L->data[i]=a[i];    
    L->length=n;    
}    
    
//初始化线性表InitList(L)    
void InitList(SqList *&L)   //引用型指针    
{    
    L=(SqList *)malloc(sizeof(SqList));    
    //分配存放线性表的空间    
    L->length=0;    
}    
    
//销毁线性表DestroyList(L)    
void DestroyList(SqList *&L)    
{    
    free(L);    
}    
    
//判定是否为空表ListEmpty(L)    
bool ListEmpty(SqList *L)    
{    
    return(L->length==0);    
}    
    
//求线性表的长度ListLength(L)    
int ListLength(SqList *L)    
{    
    return(L->length);    
}    
    
//输出线性表DispList(L)    
void DispList(SqList *L)    
{    
    int i;    
    if (ListEmpty(L)) return;    
    for (i=0; i<L->length; i++)    
        printf("%d ",L->data[i]);    
    printf("\n");    
}    
    
//求某个数据元素值GetElem(L,i,e)    
bool GetElem(SqList *L,int i,ElemType &e)    
{    
    if (i<1 || i>L->length)  return false;    
    e=L->data[i-1];    
    return true;    
}    
    
//按元素值查找LocateElem(L,e)    
int LocateElem(SqList *L, ElemType e)    
{    
    int i=0;    
    while (i<L->length && L->data[i]!=e) i++;    
    if (i>=L->length)  return 0;    
    else  return i+1;    
}    
    
//插入数据元素ListInsert(L,i,e)    
bool ListInsert(SqList *&L,int i,ElemType e)    
{    
    int j;    
    if (i<1 || i>L->length+1)    
        return false;   //参数错误时返回false    
    i--;            //将顺序表逻辑序号转化为物理序号    
    for (j=L->length; j>i; j--) //将data[i..n]元素后移一个位置    
        L->data[j]=L->data[j-1];    
    L->data[i]=e;           //插入元素e    
    L->length++;            //顺序表长度增1    
    return true;            //成功插入返回true    
}    
    
//删除数据元素ListDelete(L,i,e)    
bool ListDelete(SqList *&L,int i,ElemType &e)    
{    
    int j;    
    if (i<1 || i>L->length)  //参数错误时返回false    
        return false;    
    i--;        //将顺序表逻辑序号转化为物理序号    
    e=L->data[i];    
    for (j=i; j<L->length-1; j++) //将data[i..n-1]元素前移    
        L->data[j]=L->data[j+1];    
    L->length--;              //顺序表长度减1    
    return true;              //成功删除返回true    
}    

主函数main.cpp:

#include "list.h"    
int main()    
{    
    SqList *sq;    
    ElemType E;    
    
    printf("初始化线性表\n");    
    InitList(sq);    
    
    printf("在第1个位置插入元素1\n");    
    ListInsert(sq, 1, 1);    
    DispList(sq);    
    
    printf("在第2个位置插入元素6\n");    
    ListInsert(sq, 2, 6);    
    DispList(sq);    
    
    
    printf("在第1个位置插入元素9\n");    
    ListInsert(sq, 1, 9);    
    DispList(sq);    
    
    printf("删除第2个位置的元素\n");    
    ListDelete(sq,2,E);    
    DispList(sq);    
    
    
    printf("销毁线性表\n");    
    DestroyList(sq);    
    DispList(sq);    
    
}    


运行结果:



知识点总结:

利用多文件组织,建立了顺序表的算法库。

学习心得:

对多文件组织有了更深的理解。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值