线性表的线性表示;初始化,输出,插入,删除,查找;

cpp 复制代码
#include <iostream>
#include <algorithm>//fill()
#define InitSize 5

using namespace std;

/*线性表:线性表示;初始化,输出,插入,删除,查找*/

//静态分配数组
typedef struct{
    int data[InitSize];
    int length_;
}Sqlist_;

//动态分配数组
typedef struct{
    int *data;
    int MaxSize,length;
}SqList;

void OutputList(SqList L){
    for(int i=0;i<L.MaxSize;i++)
        printf("%d ",L.data[i]);
    printf("\n");
}

void InitList(SqList &L){
    L.MaxSize=InitSize;
    L.length=L.MaxSize-1;
    //L.data=(int *)malloc(sizeof(int)*L.MaxSize);
    L.data=new int[L.MaxSize];
    fill(L.data,L.data+L.MaxSize,-1);
    for(int i=0;i<L.length;i++)
        L.data[i]=i;
}

//插入
bool ListInsert(SqList &L,int i,int e){
    for(int j=L.length;j>=i;j--){
        L.data[j]=L.data[j-1];
    }
    L.data[i]=e;
    L.length++;
    return true;
}

//删除
bool ListDelete(SqList &L,int i){
    for(int j=i;j<L.length-1;j++)
        L.data[j]=L.data[j+1];
    L.length--;
    fill(L.data+L.length,L.data+L.MaxSize,-1);
}

//查找
int LocateElem(SqList L,int e){
    for(int i=0;i<L.length;i++)
        if(L.data[i]==e)
            return i;
    return -1;
}

int main()
{
    /*线性表:线性表示;初始化,输出,插入,删除,查找*/
    SqList L;

    InitList(L);
    OutputList(L);

    ListInsert(L,1,9);
    OutputList(L);

    ListDelete(L,1);
    OutputList(L);

    LocateElem(L,1);
    printf("%d",LocateElem(L,1));

    return 0;
}
相关推荐
权泽谦8 分钟前
从零搭建一个 PHP 登录注册系统(含完整源码)
android·开发语言·php
CoovallyAIHub9 分钟前
终结AI偏见!Sony AI发布Nature论文与FHIBE数据集,重塑公平性评估基准
深度学习·算法·计算机视觉
7澄112 分钟前
深入解析 LeetCode 1572:矩阵对角线元素的和 —— 从问题本质到高效实现
java·算法·leetcode·矩阵·intellij-idea
PieroPc14 分钟前
用python Streamlit 做个RapidOCR 文本识别系统
开发语言·python·ocr
ALex_zry14 分钟前
c20 字符串处理优化可选方案
算法
阳光明媚sunny17 分钟前
分糖果算法题
java·算法
卡提西亚20 分钟前
一本通网站1125题:矩阵乘法
c++·算法·矩阵·编程题·一本通
暖木生晖24 分钟前
Javascript函数之匿名函数以及立即执行函数的使用方法?
开发语言·javascript·ecmascript
say_fall32 分钟前
C语言容易被忽略的易错点(2)
c语言·开发语言
syker43 分钟前
NEWBASIC 2.06.7 API 帮助与用户使用手册
开发语言·人工智能·机器学习·自动化