目录
1.线性表的类型定义
相当于一个数组
data:image/s3,"s3://crabby-images/3f66f/3f66f03850535d5245e830eb515fbd950f4a3076" alt=""
2.基本操作
data:image/s3,"s3://crabby-images/ea823/ea823f1601ceee5def611a22a9e2a11f3d20767f" alt=""
3.线性表的存储结构
data:image/s3,"s3://crabby-images/d88e9/d88e913adfa9f3f417a7eb7b798b00cb8d3ff8df" alt=""
4.补充
1.元素类型说明
2.数组定义data:image/s3,"s3://crabby-images/eb223/eb2233e9e7ea9986c417d7d76dda4be38e0630f9" alt=""
3.c语言的内存动态分配
计算出所需的大小再将它的指针赋值给data
4.c++的动态存储分配
data:image/s3,"s3://crabby-images/91dee/91deebd8d0443bc084e25477ba4763c0be44f0e1" alt=""
5.c++中的参数传递
引用类型作参数
使用引用后传进函数的就是a和b本身,并没有重新复制一份
data:image/s3,"s3://crabby-images/49c91/49c9119083ba22c99c7b384ed09536e2c19db53a" alt=""
6.顺序表基本操作的实现
1.线性表的初始化
data:image/s3,"s3://crabby-images/7d352/7d352592a09cdcc2e696291063e8536dd269c399" alt=""
代码示例:
cpp
typedef struct{
int *elem;
int length;
}sqlist;
bool init_sqlist(sqlist &l)
{
l.elem = new int[100];
if(!l.elem) exit(-2);
l.length = 0;
return 1;
}
2.销毁线性表,清空线性表
代码示例:
cpp
void destory_list(sqlist &l)
{
if(l.elem) delete l.elem;
}
void clear_list(sqlist &l)
{
l.length = 0;
}
3.求线性表长度,判断线性表是否为空
data:image/s3,"s3://crabby-images/ae741/ae741173aa14d3021c3763edbb0c4d84118d7ca2" alt=""
代码示例:
cpp
int getlength(sqlist &l)
{
return l.length;
}
bool isempty(sqlist &l)
{
if(l.length == 0) return 1;
else return 0;
}
4.顺序表的取值
代码示例:
cpp
int getelem(sqlist &l,int i,int &e)
{
if(i < 1 || i > l.length) return -1;
e = l.elem[i-1];
return 1;
}
5.顺序表的查找
data:image/s3,"s3://crabby-images/42b89/42b897c6c6e86d2628b101c0da1051517473cf11" alt=""
代码示例:
cpp
int locateelem(sqlist & l,int e)
{
for(int i = 0; i < l.length; i++)
{
if(l.elem[i] == e) return i + 1;
}
return 0;
}
6.顺序表的插入
data:image/s3,"s3://crabby-images/f6a11/f6a118e1ee86c9d3b56bd3c08c0ab72d56680283" alt=""
代码示例:
cpp
int insert(sqlist &l,int i,int e)
{
if(i < 1 || i > l.length + 1) return 0;
if(l.length == 100) return 0;
for(int j = l.length - 1;j >= i - 1;j--)
{
l.elem[j + 1] = l.elem[j];
}
l.elem[i - 1] = e;
l.length ++;
return 1;
}
7.顺序表的删除
data:image/s3,"s3://crabby-images/972eb/972ebd9834da57ee47e3d61cf9d1aa19ab8eb06e" alt=""
代码示例:
cpp
int deletelist(sqlist &l,int i)
{
if(i < 1 || i > l.length) return 0;
for(int j = i; j <= l.length - 1; j++)
{
l.elem[j - 1] = l.elem[j];
}
l.length--;
return 1;
}
7.顺序表的操作算法分析
data:image/s3,"s3://crabby-images/1ae71/1ae718a26ff466664d85cc35030cf59fbfb2bcac" alt=""
data:image/s3,"s3://crabby-images/cdb74/cdb74999a6be75e21fb4c6a99236cc6c7b6b1226" alt=""
8.总的代码及示例
cpp
#include<bits/stdc++.h>
using namespace std;
typedef struct{
int *elem;
int length;
}sqlist;
void init_sqlist(sqlist &l)
{
l.elem = new int[100];
l.length = 0;
}
void destory_list(sqlist &l)
{
if(l.elem) delete l.elem;
}
void clear_list(sqlist &l)
{
l.length = 0;
}
int getlength(sqlist &l)
{
return l.length;
}
bool isempty(sqlist &l)
{
if(l.length == 0) return 1;
else return 0;
}
int getelem(sqlist &l,int i,int &e)
{
if(i < 1 || i > l.length) return -1;
e = l.elem[i-1];
return 1;
}
int locateelem(sqlist & l,int e)
{
for(int i = 0; i < l.length; i++)
{
if(l.elem[i] == e) return i + 1;
}
return 0;
}
int insert(sqlist &l,int i,int e)
{
if(i < 1 || i > l.length + 1) return 0;
if(l.length == 100) return 0;
for(int j = l.length - 1;j >= i - 1;j--)
{
l.elem[j + 1] = l.elem[j];
}
l.elem[i - 1] = e;
l.length ++;
return 1;
}
bool deletelist(sqlist &l,int i)
{
if(i < 1 || i > l.length) return 0;
for(int j = i; j <= l.length - 1; j++)
{
l.elem[j - 1] = l.elem[j];
}
l.length--;
return 1;
}
int main()
{
sqlist l;
init_sqlist(l);
cout << getlength(l) << endl;
insert(l,1,1);
insert(l,2,10);
insert(l,3,100);
insert(l,4,1000);
insert(l,5,10000);
cout << locateelem(l,100) << endl;
cout << locateelem(l,10000) << endl;
cout << getlength(l) << endl;
deletelist(l,3);
cout << getlength(l) << endl;
return 0;
}