线性表之顺序表C++实现
线性表之顺序表
一、头文件:SeqList.h
//顺序线性表的头文件
#include<iostream> const int MaxSize = ;
//定义顺序表SeqList的模板类
template<class DataType>
class SeqList{
public:
//顺序表无参构造器(创建一个空的顺序表)
SeqList(){ length = }
//顺序表有参构造器(创建一个长度为n的顺序表)
SeqList(DataType array[], int n);
//顺序表析构函数
~SeqList(){}
//求顺序表的长度
int GetLength(){ return length; }
//顺序表按位查找,返回i位置的元素
DataType GetElement(int i);
//顺序表按值查找,返回该元素所在的位置
int GetLocal(DataType x);
//顺序表在指定的位置插入指定的元素
void Insert(int i, DataType x);
//顺序表删除元素,返回删除的元素
DataType Delete(int i);
//输出顺序表中的元素
void PrintSeqList();
private:
//一维数组,存放数据元素
DataType data[MaxSize];
//顺序表的长度
int length;
}; //实现顺序表有参构造器
template<class DataType>
SeqList<DataType>::SeqList(DataType array[], int n)
{
if (n > MaxSize)
{
throw "传入的顺序表长度过长";
}
//给顺序表的存储元素的数组赋值
for (int i = ; i < n; i++)
{
data[i] = array[i];
}
//给顺序表的长度赋值
length = n;
} //实现顺序表按位查找
template<class DataType>
DataType SeqList<DataType>::GetElement(int i)
{
//判断是定的位置是否合理
if (i < || i >length)
{
throw "位置有误";
}
else
{
//返回指定位置的元素
return data[i - ];
}
} //实现顺序表按值查找,返回该元素所在的位置
template<class DataType>
int SeqList<DataType>::GetLocal(DataType x)
{
//遍历顺序表的元素
for (int i = ; i < length; i++)
{
//判断指定的元素是否在顺序表中
if (data[i] == x)
{
//返回指定元素在顺序表中的位置
return (i + );
}
}
//如果指定的元素不在顺序表中,则返回位置为0
return ;
} //实现顺序表插入元素
template<class DataType>
void SeqList<DataType>::Insert(int index, DataType x)
{
//判断插入的位置是否合理
if (length >= MaxSize)
{
throw "顺序表已存放满";
}
if (index< || index>length + )
{
throw "插入元素的位置有误";
}
//如何插入的位置合理,则把顺序表中从最后位置到指定插位置的元素整体向后移动一个位置
for (int j = length; j >= index; j--)
{
data[j] = data[j - ];
}
//给插入的位置放入指定的元素
data[index - ] = x;
length++;
} //实现顺序表删除指定位置的元素
template<class DataType>
DataType SeqList<DataType>::Delete(int index)
{
//声明要取出的元素
DataType x;
//判断要删除的位置是否合理
if (index< || index>length)
{
throw "删除的位置有误";
}
else
{
//取出指定位置的元素
x = data[index-];
//将指定位置后的元素全部都向前移动一个位置
for (int i = index; i < length; i++)
{
data[i - ] = data[i];
}
//删除顺序表中的元素后,其长度减1
length--;
}
return x;
} //顺序输出顺序表中的元素
template<class DataType>
void SeqList<DataType>::PrintSeqList()
{
if (length < )
{
throw "顺序表中没有元素";
}
else
{
//顺序输出顺序表元素
for (int i = ; i < length; i++)
{
cout << data[i] << " ";
}
cout << endl;
}
}
二、测试线性表之顺序表:TestSeqList.cpp
#include<iostream>
#include"SeqList.h"
using namespace std;
void show()
{
cout << "---------------------------------------" << endl;
}
int main()
{
int array[] = {,,,,,,,,,};
SeqList<int> seqList = SeqList<int>(array,);
cout << "顺序表为:" << endl;
seqList.PrintSeqList();
show();
cout << "顺序表的长度为:" << seqList.GetLength()<< endl;
cout << "第三个位置的元素是:" << seqList.GetElement() << endl;
cout << "元素3的位置是:" << seqList.GetLocal() << endl;
show();
cout << "在第5个位置插入元素22" << endl;
seqList.Insert(, );
cout << "顺序表为:" << endl;
seqList.PrintSeqList();
cout << "顺序表的长度为:" << seqList.GetLength() << endl;
show();
cout << "删除第5个位置的元素" << endl;
seqList.Delete();
cout << "顺序表为:" << endl;
seqList.PrintSeqList();
cout << "顺序表的长度为:" << seqList.GetLength() << endl;
show();
return ;
}
三、运行示例结果
线性表之顺序表C++实现的更多相关文章
- C#线性表之顺序表
线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract), 线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 这种一对一的关系指的是数据元素之间的位置关系,即: ...
- c/c++ 线性表之顺序表
线性表之顺序表 存储在连续的内存空间,和数组一样. 下面的代码,最开始定义了一个能存8个元素的顺序表,当超过8个元素的时候,会再追加开辟空间(函数:reInit). 实现了以下功能: 函数 功能描述 ...
- [C++]线性链表之顺序表<一>
顺序表中数据元素的存储地址是其序号的线性函数,只要确定了存储顺序表的起始地址(即 基地址),计算任意一个元素的存储地址的时间是相等的,具有这一特点的存储结构称为[随机存储]. 使用的基本数据结构:数组 ...
- [C++]线性链表之顺序表<二>
/* @content 线性链表之顺序表 @date 2017-3-21 1:06 @author Johnny Zen */ /* 线性表 顺序表 链式表[带头指针/不 ...
- [C++]数据结构:线性表之顺序表
1 顺序表 ADT + Status InitList(SeqList &L) 初始化顺序表 + void printList(SeqList L) 遍历顺序表 + int ListLengt ...
- [数据结构 - 第3章] 线性表之顺序表(C++实现)
一.类定义 顺序表类的定义如下: #ifndef SEQLIST_H #define SEQLIST_H typedef int ElemType; /* "ElemType类型根据实际情况 ...
- 数据结构Java实现02----线性表与顺序表
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- 数据结构Java实现01----线性表与顺序表
一.线性结构: 如果一个数据元素序列满足: (1)除第一个和最后一个数据元素外,每个数据元素只有一个前驱数据元素和一个后继数据元素: (2)第一个数据元素没有前驱数据元素: (3)最后一个数据元素没有 ...
- C# 数据结构 线性表(顺序表 链表 IList 数组)
线性表 线性表是最简单.最基本.最常用的数据结构.数据元素 1 对 1的关系,这种关系是位置关系. 特点 (1)第一个元素和最后一个元素前后是没有数据元素,线性表中剩下的元素是近邻的,前后都有元素. ...
随机推荐
- [转]大整数算法[11] Karatsuba乘法
★ 引子 前面两篇介绍了 Comba 乘法,最后提到当输入的规模很大时,所需的计算时间会急剧增长,因为 Comba 乘法的时间复杂度仍然是 O(n^2).想要打破乘法中 O(n^2) ...
- 连接数据库及出现System.AccessViolationException错误的解决方法
调试后发现, connection.Open();以后报错,System.AccessViolationException: 尝试读取或写入受保护的内存.这通常指示其他内存已损坏,网上搜了很多都没有作 ...
- JDk1.8源码StringBuffer
一.概念 StringBuffer A thread-safe, mutable sequence of characters. A string buffer is like a {@link St ...
- from setuptools import setup ImportError: No module named setuptools【转】
转自:http://www.cnblogs.com/chinacloud/archive/2010/12/24/1915644.html from setuptools import setupImp ...
- Centos 软连接和硬链接
1.软链接: 建立软链接:ln -s /usr/local/node-v4.2.6-linux-x86/bin/node /usr/local/bin/node 解释:将/usr/local/node ...
- 你真的了解js伪数组吗?深入js伪数组
关于js伪数组 具有length属性: 按索引方式存储数据: 不具有数组的push().pop()等方法: 你可能知道怎么把伪数组转换为数组,但是你知道这里边的原理吗? 假如页面有一组li元素 < ...
- java基础81 jsp的内置对象(网页知识)
1.什么是内置对象? 在jsp开发中,会频繁使用到一些对象,如:HttpSession,ServletContext,HttpServletRequest. 如果每次使用这些对象时,都要去创 ...
- No.3 selenium学习之路之鼠标&键盘事件
鼠标事件 from selenium.webdriver.common.action_chains import ActionChains contest_click() 右击 double_cli ...
- java 多线程总结篇4——锁机制
在开发Java多线程应用程序中,各个线程之间由于要共享资源,必须用到锁机制.Java提供了多种多线程锁机制的实现方式,常见的有synchronized.ReentrantLock.Semaphore. ...
- Luogu P3384 【【模板】树链剖分】
转载请注明出处,部分内容引自banananana大神的博客 ~~别说你不知道什么是树~~╮(─▽─)╭(帮你百度一下) 先来回顾两个问题:1,将树从x到y结点最短路径上所有节点的值都加上z 这也是个模 ...