/*
  @content 线性链表之顺序表
  @date 2017-3-21 1:06
  @author Johnny Zen 
*/
/*
线性表
    顺序表
    链式表[带头指针/不带头指针] 
    单链表
    循环单链表 
双向链表
循环双链表      
ADT
 
List{ 
属性:
  length     长度
  DataList;        数据 
操作:
  init(array[])   表初始化
  Destory()    表销毁
  int getLength()  返回表的长度
  void InsertNode(int i,node) 按照位置i,插入表的结点
  void DeleteNode(int i,node) 按照位置i,删除表的结点
  void Delete(data)           按值删除表的结点 
  int Location(data)          按值查找,返回位置i[实际位置]
  Data Get(i)                 按位置查找,返回结点数据
  void sort()                 结点排序 
  bool Empty()                判空    
  void print()                遍历表   
*/
 
//=================================
//顺序表
#include<iostream>
using namespace std;
 
const int MaxSize = 100;
template<class T>
class SeqList{
public:
  SeqList();
  SeqList(T a[],int n);
  ~SeqList();
  int  Length(){ return length; }
    
  void Insert(int x,T data);
  void Delete(int x);
  int  Location(T data);
  T    Get(int i); 
 
  void print();
  bool Empty();
 
private:
  int length;
  T datas[MaxSize];   
}; 
 
/***************方法实现区*******************/
template<class T>
SeqList<T>::SeqList(){
  length = 0;
}
 
template<class T>
SeqList<T>::SeqList(T a[],int n){
  if(n>MaxSize){
    throw "数组长度超出!!";
  }
    
  for(int i = 0;i<n;i++){
    datas[i] = a[i];
  }
  length = n;
}
 
template<class T>
SeqList<T>::~SeqList(){ }
 
//插入到第i个位置上(实际位置)
//    1 2 45 75 | 75 45 45  1 2
//    0 1 2  3  |  4  5  6  7 8
//    12 12 56  | 78 11  
// i = 5 
// [5] = [4]
// [4] = [3]
// [3] = [2]
// [2] = [1]
// [1] = [0]
template<class T>
void SeqList<T>::Insert(int x,T data){ 
  if(x>length+1||x<1)
    throw "位置超界!!!";
  if(length>=MaxSize)
    throw "位置溢出!!!";  
 
  for(int i=length;i>=x;i--){
    this->datas[i] = this->datas[i-1];  //最关键代码:从后面[length]开始往前走,元素向后挪 
  }
 
  this->datas[x-1] = data;
  length++;
 
//按位置i(实际位置)删除结点 
//    1 2 45 75 | 75 45 45  1 2
//    0 1 2  3  |  4  5  6  7 8
//    12 12 56  | 78 11 
template<class T>
void SeqList<T>::Delete(int x){  
    
    if(x<1||x>length)
          throw "位置异常";
      
  for(int i=x-1;i<length-1;i++) 
    this->datas[i] = this->datas[i+1]; 
    
  length--;
 
//按值查找,返回位置(实际位置)
template<class T> 
int  SeqList<T>::Location(T data){
  datas[length] = data;     //在最后一个结点的后面设置哨兵 
  int i = 0;
  while(datas[i]!=data) 
    i++;
  if(i==length) return -1;  
    return ++i;      
}
 
//按位置(实际位置)查找,返回结点值 
template<class T>
T  SeqList<T>::Get(int i){
  if(i<1||i>length)
    throw "位置超界!!!";
  return datas[i-1];
 
//遍历顺序表 
template<class T>
void SeqList<T>::print(){
  for(int i = 0;i<this->Length();i++)
    cout<<datas[i]<<"\t";
}
 
template<class T>
bool SeqList<T>::Empty(){
  if(length>0) 
    return false; //0
  return true;    //1
}      
 
//=================================
int main(){
  int arr[]= {12,23,45,56,78};
  SeqList<int> test(arr,5);
 
  cout<<test.Get(5)<<endl; 
  cout<<test.Empty()<<endl;
  test.print();
  return 0;
}

[C++]线性链表之顺序表<二>的更多相关文章

  1. [C++]线性链表之顺序表<一>

    顺序表中数据元素的存储地址是其序号的线性函数,只要确定了存储顺序表的起始地址(即 基地址),计算任意一个元素的存储地址的时间是相等的,具有这一特点的存储结构称为[随机存储]. 使用的基本数据结构:数组 ...

  2. [Java算法分析与设计]--线性结构与顺序表(List)的实现应用

    说到线性结构,我们应该立马能够在脑子里蹦出"Array数组"这个词.在Java当中,数组和对象区别基本数据类型存放在堆当中.它是一连串同类型数据存放的一个整体.通常我们定义的方式为 ...

  3. 数据结构:队列 链表,顺序表和循环顺序表实现(python版)

    链表实现队列: 尾部 添加数据,效率为0(1) 头部 元素的删除和查看,效率也为0(1) 顺序表实现队列: 头部 添加数据,效率为0(n) 尾部 元素的删除和查看,效率也为0(1) 循环顺序表实现队列 ...

  4. C# 数据结构 线性表(顺序表 链表 IList 数组)

    线性表 线性表是最简单.最基本.最常用的数据结构.数据元素 1 对 1的关系,这种关系是位置关系. 特点 (1)第一个元素和最后一个元素前后是没有数据元素,线性表中剩下的元素是近邻的,前后都有元素. ...

  5. 【PHP数据结构】线性表?顺序表?链表?别再傻傻分不清楚

    遵从所有教材以及各类数据结构相关的书书籍,我们先从线性表开始入门.今天这篇文章更偏概念,是关于有线性表的一个知识点的汇总. 上文说过,物理结构是用于确定数据以何种方式存储的.其他的数据结构(树.图). ...

  6. 线性表之顺序表(C语言实现)

    线性表是从数据元素的逻辑结构上定义的. 这种数据元素的逻辑结构的特征如下: 1.除开第一个和最后一个元素之外.所有元素都有一个前驱元素和后继元素. 2.第一个元素无前驱元素,但有后继元素. 3.最后一 ...

  7. [Python] 数据结构--实现顺序表、链表、栈和队列

    说明: 本文主要展示Python实现的几种常用数据结构:顺序表.链表.栈和队列. 附有实现代码. 来源主要参考网络文章. 一.顺序表 1.顺序表的结构 一个顺序表的完整信息包括两部分,一部分是表中元素 ...

  8. 数据结构中的顺序表和链表(Python语言)

    转载:https://blog.csdn.net/weixin_43187669/article/details/96426362 算法是为了解决实际问题而设计的,数据结构是算法需要处理的问题载体. ...

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

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

随机推荐

  1. PostgreSQL、SQL Server数据库中的数据类型的映射关系

    PostgreSQL 8.1 轰动发布,我也打算将原来使用 SQL Server 的一些应用迁移到 PostgreSQL 上,首先需要迁移的是表,那么这就必须要先搞清楚这两个数据库中的数据类型的映射关 ...

  2. js函數

    函數是什麼?函數就是被事件驅動或者調用執行的可重複的代碼塊. 函數聲明: 使用關鍵詞function,關鍵詞function大小敏感. function a{代碼塊} 局部變量: 在函數內部聲明的變量 ...

  3. codeforces3A

    Shortest path of the king CodeForces - 3A 棋盘上的国王被单独放置.尽管他是孤独的,但并未伤心,因为他有事关全局的重要性.例如,他必须正式访问方格 t .由于国 ...

  4. [转载]使用VS2015搭建Lua开发环境

    参考原文请看: Lua学习笔记1:Windows7下使用VS2015搭建Lua开发环境(一) Lua学习笔记2:Windows7下使用VS2015搭建Lua开发环境(二) 本篇主要分以下几个部分: 一 ...

  5. BZOJ4538 HNOI2016网络(树链剖分+线段树+堆/整体二分+树上差分)

    某两个点间的请求只对不在这条路径上的询问有影响.那么容易想到每次修改除该路径上的所有点的答案.对每个点建个两个堆,其中一个用来删除,线段树维护即可.由于一条路径在树剖后的dfs序中是log个区间,所以 ...

  6. (python爬取小故事网并写入mysql)

    前言: 这是一篇来自整理EVERNOTE的笔记所产生的小博客,实现功能主要为用广度优先算法爬取小故事网,爬满100个链接并写入mysql,虽然CS作为双学位已经修习了三年多了,但不仅理论知识一般,动手 ...

  7. 自学Zabbix12.3 Zabbix命令-zabbix_agentd

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 自学Zabbix12.3 Zabbix命令-zabbix_agentd 1. zabbix_age ...

  8. [luogu3258][JLOI2014]松鼠的新家

    题解 我们就在\([a_i,a_{i+1}]\)的路径上都\(+1\),然后单点查询就可以了. ac代码(吸了氧才过的QwQ) # include <bits/stdc++.h> # de ...

  9. NOIp2017D2T1(luogu3968) 奶酪 (并查集)

    并查集. 判相切或相交的时候可以两边同时平方,就不需要double和开根号了. #include<cstdio> #include<cstring> #include<a ...

  10. wechat 网页版通信全过程

    想要记录总结一下自己在这个小项目中所遇到的坑,以及解决问题的思路. 首先我觉得这个小项目挺有实际市场的,市场上有一定的需求量,这个就是驱动力吧.这个小项目的关键点是wechat网页版通信全过程,讲真挺 ...