顺序表(C++实现)
类实现代码如下:
;//默认的表空间大小
template <class T>
class SeqList{
protected:
T *data;//存放数组
int maxSize;//表空间总大小
int last;//当前表中最后一个元素的位置(从0开始计算)
void reSize(int newSize);//重新设定表空间大小
public:
SeqList(int sz=defaultSize){//构造函数
maxSize=sz;
last=-;
data=new T[sz];
);
}
SeqList(SeqList<T>& L){//拷贝构造函数
maxSize=L.size();
last=L.length()-;
data=new T[maxSize];
);
T value;
;i<=last;i++){
L.getData(i+,value);
data[i]=value;
}
}
~SeqList(){//析构函数
delete[] data;
}
int size()const{//表空间总大小
return maxSize;
}
int length()const{//表中元素的总个数
;
}
int search(T &x)const{//返回元素X在表中的位置(从1开始计算)
;i<=last;i++){
;
}
;
}
bool getData(int i,T &x)const{//取第i个表项的值放到x中(从1开始计算)
&&i<=last+){
x=data[i-];
return true;
}else{
return false;
}
}
void setData(int i,T &x){//将x中的值放到第i个表项中 (从1开始计算)
&&i<=last+){
data[i-]=x;
}
}
bool insert(int i,T& x){//插入x在第i个表项后 (从1开始计算)
) return false;
||i>last+) return false;
for(int j=last;j>=i;j--)
data[j+]=data[j];
data[i]=x;
last++;
return true;
}
bool remove(int i,T &x){//删除第i个表项值,并放入x (从1开始计算)
) return false;
||i>last+) return false;
x=data[i-];
for(int j=i;j<=last;j++)
data[j-]=data[j];
last--;
return true;
}
bool isFull(){//判断表是否为空
)?true:false;
}
bool isEmpty(){//判断表是否为满
)?true:false;
}
void input(){//输入
while(true){
cout<<"请先输入你需要输入表中元素的个数:(不能超过"<<maxSize<<")";
cin>>last;
last--;
) break;
}
cout<<"输入元素:"<<endl;
;i<=last;i++)
cin>>data[i];
}
void output(){//输出
cout<<"输出元素:"<<endl;
;i<=last;i++)
cout<<data[i]<<" ";
cout<<endl;
}
//SeqList<T> operator=(SeqList<T> &L);“=”重载,功能、函数实现同拷贝构造函数
};
测试代码如下:
void menu(){
cout<<"1.输入一组元素"<<endl;
cout<<"2.输出一组元素"<<endl;
cout<<"3.取第i个表项的值放到x中(从1开始计算) "<<endl;
cout<<"4.将x中的值放到第i个表项中 (从1开始计算) "<<endl;
cout<<"5.插入x在第i个表项后 (从1开始计算) "<<endl;
cout<<"6.删除第i个表项值,并放入x (从1开始计算)"<<endl;
cout<<"7.返回元素X在表中的位置(从1开始计算)"<<endl;
cout<<"8.调用拷贝构造函数"<<endl;
cout<<"9.退出"<<endl;
}
template <class T>
void function(int num,SeqList<T> *sl){
int i;T x;
switch(num){
:
sl->input();
break;
:
sl->output();
break;
:
cin>>i;
sl->getData(i,x);
cout<<x<<endl;
break;
:
cin>>x>>i;
sl->setData(i,x);
break;
:
cin>>x>>i;
sl->insert(i,x);
break;
:
cin>>i;
sl->remove(i,x);
break;
:
cin>>x;
i=sl->search(x);
cout<<i<<endl;
break;
:
{
SeqList<T> *sl2=new SeqList<T>(*sl);
sl2->output();
// sl->remove(2,x);
// sl2->output();
delete sl2;
}//这里要用花括号!http://www.cnblogs.com/RealOnlyme/articles/2579628.html
break;
default:
exit();
}
}
int main(int argc, char** argv) {
int x;
SeqList<int> *sl=new SeqList<int>();
while(true){
menu();
cin>>x;
function(x,sl);
}
delete sl;
;
}
小结:
1.顺序表中各个元素必须相继存放于一个连续的空间内,不准跳跃地存放。(与一维数组的区别)
2.顺序表中最复杂的操作就是搜索,插入和删除运算。
3.分析搜索的时间代价主要看循环内数据的比较次数,次数从1到n,平均比较(n+1)/2个表项。
4.分析插入删除的时间代价主要看循环内的数据移动次数。插入时有n+1个插入位置,移动次数从0到n,平均移动n/2个表项;删除时有n个删除位置,移动次数从0到n-1,平均移动(n-1)/2个表项。
顺序表(C++实现)的更多相关文章
- jdk顺序表笔记
一.AbstractCollection 提供了集合的最大实现 继承该类,必须实现size()和iterator(),因为该类操作集合都是通过iterator 二.fail-fast策略 该策略在集合 ...
- c++顺序表基本功能
头文件 #define LIST_MAX_SIZE 5#define LISTINCREMENT 2#include<assert.h>#include<string>temp ...
- 数据结构:顺序表(python版)
顺序表python版的实现(部分功能未实现) #!/usr/bin/env python # -*- coding:utf-8 -*- class SeqList(object): def __ini ...
- 《数据结构》2.2顺序表(sequence list)
//顺序表节点的定义 typedef struct { datatype data[MAXSIZE]; //数组容量的上限 int len; //记录最后一个元素的位置,相当于一个指针,表空时len= ...
- c数据结构 顺序表和链表 相关操作
编译器:vs2013 内容: #include "stdafx.h"#include<stdio.h>#include<malloc.h>#include& ...
- java顺序表和树的实现
一.顺序表 1.线性表 //java顺序表的实现,如ArrayList就是用线性表实现的,优点是查找快,缺点是添加或删除要移动很多元素,速度慢 public class SequenceList { ...
- 数据结构顺序表删除所有特定元素x
顺序表类定义: template<class T> class SeqList : { public: SeqList(int mSize); ~SeqList() { delete[] ...
- 顺序表C语言版
#include <stdio.h> /* * 顺序表最多输入N个数 */ #define N 10 #define OK 1 #define ERROR -1 struct sequeu ...
- C#线性表之顺序表
线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract), 线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 这种一对一的关系指的是数据元素之间的位置关系,即: ...
- C语言 线性表 顺序表结构 实现
一个能够自动扩容的顺序表 ArrList (GCC编译). #include <stdio.h> #include <stdlib.h> #include <string ...
随机推荐
- classnull100 - The 3n + 1 problem
新手发帖,很多方面都是刚入门,有错误的地方请大家见谅,欢迎批评指正 The 3n + 1 problem Background Problems in Computer Science are o ...
- Oracle EBS中分类账和法人实体 的关系(有sql语句实例)
Oracle EBS中分类账和法人实体 的关系(有sql语句实例) 2012-12-06 16:05 2822人阅读 评论(0) 收藏 举报 分类: Oracle EBS(12) Oracle数据 ...
- git多人合作模式的应用
接触git只有不到一年的时间,可以说比大多数人起步都晚.那会还沉浸在自己的舒适圈里面,进公司就用着perforce,一用就快7年,觉得自己会用一个SCM就行了,捧着不放,也不想去接触别的SCM. 直到 ...
- Leaving Auction
Leaving Auction 题目链接:http://codeforces.com/contest/749/problem/D 二分 本来以为是哪种神奇的数据结构,没想到sort+lower_bon ...
- CentOS7 install vsftpd
#mkdir -p /var/ftp/xcl/ #yum install -y vsftpd#useradd -g ftp -M -d /var/ftp/xcl -s /sbin/nologin xc ...
- __builtin_expect
今天在看内核代码中看到: #define likely(x) __builtin_expect(!!(x), 1)#define unlikely(x) __builtin_expect(!!(x), ...
- 实战ASP.NET访问共享文件夹(含详细操作步骤)
博客园找找看(http://zzk.cnblogs.com)的索引文件占用空间太大,需要移至另外一台服务器,所以要解决"在ASP.NET中通过共享文件夹访问索引文件"的问题. 假设 ...
- NGINX----源码阅读---config配置脚本
config文件为nginx的配置入口文件. 1. #!/bin/sh # Copyright (C) Igor Sysoev # Copyright (C) Nginx, Inc. LC_ALL=C ...
- 在Linux中设置自启动服务或程序
三种方法: 1.基于linux的system V机制,其中有个运行级别和链接软连接指向服务脚本的机制. 服务脚本一般处于/etc/init.d/目录下, 而运行级别制定的默认执行脚本在/etc/rc. ...
- mac下 redis安装使用
安装redis:brew install redis 开启redis服务:redis-server /usr/local/etc/redis.conf 重新打开一个命令窗口:redis-cli ,进入 ...