//SequentialList.h 顺序表模板类

#ifndef SEQUENTIAL_LIST_HXX
#define SEQUENTIAL_LIST_HXX

using std::cout;

using std::endl;

const int MaxSize=100;   //顺序表数组最大值

template<class T>
class SeqList    //定义模板类SeqList(顺序表)
{
  public:

    SeqList() { length=0; }    //无参构造函数,建立一个空的顺序表
    SeqList(T a[],int n);      //有参构造函数,建立一个长度为n的顺序表 n不大于MaxSize
    ~SeqList() {}         //析构函数

    int Length() { return length; } //求线性表长度

    T Get(int i);          //按位查找,在线性表中查找第i个元素

    int Locate(T x);        //按值查找,在线性表中找值为x的元素序号

    void Insert(int i,T x);     //插入操作,在线性表中的第i个位置插入值为x的元素

    T Delete(int i);        //删除操作,删除线性表的第i个元素

    void PrintList();        //遍历操作,按序号依次输出各元素

  private:
    T data[MaxSize];      //存放数据元素的数组
    int length;         //线性表的长度
};

template<class T>
SeqList<T>::SeqList(T a[],int n)
{
  if(n>MaxSize) throw "参数非法";
  for(int i=0;i<n;i++)
    data[i]=a[i];
  length=n;
}

template<class T>
T SeqList<T>::Get(int i)
{
  if(i<1||i>length) throw "参数非法";
  return data[i-1];
}

template<class T>
int SeqList<T>::Locate(T x)
{
  for(int i=0;i<length;i++)
  if(data[i]==x) return i+1;  //下标为i的元素等于x,返回其序号i+1
  return 0;           //退出循环,说明查找失败
}

template<class T>
void SeqList<T>::Insert(int i,T x)
{
  if(length>=MaxSize) throw "上溢";
  if(i<1||(i>length+1)) throw "位置溢出";
  for(int j=length;j>=i;j--)
    data[j]=data[j-1];       //注意第j个元素存在于数组小标为j-1处
  data[i-1]=x;
  length++;
}

template<class T>
T SeqList<T>::Delete(int i)
{
  if(length==0) throw "下溢";
  if(i<1||i>length) throw "位置";
  T x=data[i];          //取出位置i的元素
  for(int j=i;j<length;j++)
    data[j-1]=data[j];      //此处j已经是元素所在的数组下表
  length--;
  return x;
}

template<class T>
void SeqList<T>::PrintList()
{
  for(int i=0;i<length;i++)
    cout<<data[i];        //依次输出线性表的元素值
}

#endif

//seqlisttest.cpp
#include <iostream>
#include "SequentialList.h"
using std::cout;
using std::endl;

int main()
{
  int m[10]={1,2,3,4,28,50,7,8,9,10};
  SeqList<int> seqList(m,10);

  cout<<"顺序表原始状态"<<endl;
  seqList.PrintList();
  cout<<"顺序表第5个元素值"<<seqList.Get(5)<<endl;
  cout<<"顺序表长度"<<seqList.Length()<<endl;

  cout<<"顺序表删除一个元素后的状态"<<endl;
  seqList.Delete(5);
  seqList.PrintList();
  cout<<"顺序表第5个元素值"<<seqList.Get(5)<<endl;
  cout<<"顺序表长度"<<seqList.Length()<<endl;

  cout<<"顺序表增加一个元素后的状态"<<endl;
  seqList.Insert(5,108);

  seqList.PrintList();

  cout<<"顺序表第5个元素值"<<seqList.Get(5)<<endl;
  cout<<"顺序表长度"<<seqList.Length()<<endl;

  cout<<"顺序表中数值=108在表中第"<<seqList.Locate(108)<<"位"<<endl;

  return 0;

}

C++ 数据结构学习一(顺序表)的更多相关文章

  1. C++数据结构学习之顺序表

    顺序表是数据结构中最基本也是应用相当广泛的一种数据结构类型.它通常包含三个私有成分,即指向数据数组的头指针.当前表长以及表的实际容量.表的头指针通常指向数据数组的基地址,通过数组的形式进行访问数据数组 ...

  2. 【数据结构】之顺序表(Java语言描述)

    之前总结过使用C语言描述的顺序表数据结构.在C语言类库中没有为我们提供顺序表的数据结构,因此我们需要自己手写,详细的有关顺序表的数据结构描述和C语言代码请见[我的这篇文章]. 在Java语言的JDK中 ...

  3. 【数据结构】之顺序表(C语言描述)

    顺序表是线性表的一种,它将元素存储在一段连续的内存空间中,表中的任意元素都可以通过下标快速的获取到,因此,顺序表适合查询操作频繁的场景,而不适合增删操作频繁的场景. 下面是使用 C语言 编写的顺序表的 ...

  4. C语言学习笔记-顺序表

    #include "stdafx.h" #include <stdio.h> #include <stdlib.h> #include "coni ...

  5. 数据结构 单链表&顺序表

    顺序表: 一般使用数组(C语言中的数组采用顺序存储方式.即连续地址存储)来描述. 优点:在于随机访问元素, 缺点:插入和和删除的时候,需要移动大量的元素. 链表: 优点:插入或删除元素时很方便,使用灵 ...

  6. 数据结构——Java实现顺序表

    一.分析 什么是顺序表?顺序表是指用一组地址连续的存储单元依次存储各个元素,使得在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中的线性表.一个标准的顺序表需要实现以下基本操作: 1.初始化顺序表 ...

  7. 数据结构之线性顺序表ArrayList(Java实现)

    一.ListMe接口: import java.util.ArrayList; //实现线性表(顺序表和链表)的接口://提供add get isEmpty size 功能public interfa ...

  8. 数据结构之动态顺序表(C实现)

    线性表有2种,分为顺序表和链表. 顺序表: 采用顺序存储方式,在一组地址连续的存储空间上存储数据元素的线性表(长度固定) 链表: 有3种,单链表.双向链表.循环链表(长度不固定) seqList.h ...

  9. 【c++版数据结构】之顺序表的实现

    SeqList.h #ifndef SEQLIST_H #define SEQLIST_H #include<iostream> using namespace std; typedef ...

随机推荐

  1. Linux多线程编程小结

     Linux多线程编程小结 前一段时间由于开题的事情一直耽搁了我搞Linux的进度,搞的我之前学的东西都遗忘了,非常烦躁的说,如今抽个时间把之前所学的做个小节.文章内容主要总结于<Linux程序 ...

  2. 【精度问题】【HDU2899】Strange fuction

    Strange fuction Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  3. 【矩阵乘法经典应用】【ZOJ3497】【Mistwa】

    题意:给定一个有向图(最多25个节点,每个节点的出度最多为4),给定起点和终点,然后从起点开始走,走到终点就停止,否则一直往下走,问能不能P步到达终点.也就是说从起点出发,走一条长度为P的路径,路径中 ...

  4. mysql binlog解析概要

    1,dump协议: 根据数据库的ip+port创建socket,如果创建成功,说明链接建立成功,接下来是使用dump协议订阅binlog 链接建立成功之后,服务端会主动向客户端发送如下问候信息gree ...

  5. UVA1600 Patrol Robot

    题意: 求机器人走最短路线,而且可以穿越障碍.N代表有N行,M代表最多能一次跨过多少个障碍. 分析: bfs()搜索,把访问状态数组改成了3维的,加了个维是当前能跨过的障碍数. 代码: #includ ...

  6. xcode新建项目介绍

    xcode新建项目介绍 1.打开xcode选择“create a new xcode project 2.product name 工程名称 campany identifter 公司id 一般都写公 ...

  7. Docker终极指南:为什么Docker能做这么多事

    Docker终极指南:为什么Docker能做这么多事 http://www.aboutyun.com/thread-11499-1-1.html

  8. Search in Sorted Array,Search in Rotated Sorted Array,Search in Rotated Sorted ArrayII

    一:Search in Sorted Array 二分查找,可有重复元素,返回target所在的位置,只需返回其中一个位置,代码中的查找范围为[low,high),左闭右开,否则容易照成死循环. 代码 ...

  9. A==?B(A,B超级大)

    #include <iostream>#include <string.h>#include <cstring>using namespace std;struct ...

  10. Unix下C程序内存泄露检测工具:valgrind的安装使用

    Valgrind是一款用于内存调试.内存泄漏检测以及性能分析的软件开发工具. Valgrind的最初作者是Julian Seward,他于2006年由于在开发Valgrind上的工作获得了第二届Goo ...