数据结构:顺序表(C++实现)

1 头文件 SeqList.h

cpp 复制代码
//SeqList.h
#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<cassert>
using namespace std;
class SeqList
{
public:
	//初始化
	SeqList();
	//销毁
	~SeqList();
	//头插
	void PushFront(int data);
	//头删
	void PopFront();
	//尾插
	void PushBack(int data);
	//尾删
	void PopBack();
	//打印
	void Print();
	//寻找
	int* Find(int data);
	//插入
	void Insert(int pos, int data);
	//清除
	void Erase(int data);
	//检查容量
	void Check();
private:
	//动态数组
	int* ptr;
	//数组索引
	int index;
	//数组容量
	int capacity;
};

2 源文件

2.1 SeqList.cpp(函数)

cpp 复制代码
//SeqList.cpp
#include "SeqList.h"
//练习顺序表
//初始化
SeqList::SeqList():ptr(nullptr)	//创建变量时即给指针赋值为空指针
{
	index = 0;
	capacity = 0;
}
//销毁
SeqList::~SeqList()
{
	if (ptr!=nullptr)
	{
		delete[]ptr;
		ptr = nullptr;
		capacity = 0;
		index = 0;
		cout << "~SeqList Destroyed" << endl;
	}
}
//头插
void SeqList::PushFront(int data)
{
	Check();
	for (int i = index - 1; i >= 0; i--)
	{
		ptr[i + 1] = ptr[i];
	}
	ptr[0] = data;
	index++;
}
//头删
void SeqList::PopFront()
{
	for (int i = 1; i < index; i++)
	{
		ptr[i - 1] = ptr[i];
	}
	index--;
}
//尾插
void SeqList::PushBack(int data)
{
	Check();
	assert(ptr);
	ptr[index++] = data;
}
//尾删
void SeqList::PopBack()
{
	assert(index >= 0);
	index--;
}
//打印
void SeqList::Print()
{
	for (int i = 0; i < index; i++)
	{
		cout << ptr[i] << " ";
	}
	cout << endl;
}
//寻找
int* SeqList::Find(int data)
{
	for (int i = 0; i < index; i++)
	{
		if (ptr[i] == data)
		{
			return ptr + i;
		}
	}
	return nullptr;
}
//插入
void SeqList::Insert(int pos, int data)
{
	assert(pos > 0);
	Check();
	for (int i = index - 1; i >= pos - 1; i--)
	{
		ptr[i + 1] = ptr[i];
	}
	ptr[pos-1] = data;
	index++;
}
//清除
void SeqList::Erase(int data)
{
	int flag = 1;
	for (int i = 0; i < index; i++)
	{
		if (ptr[i] == data)
		{
			for (int j = i; j <index; j++)
			{
				ptr[j] = ptr[j + 1];
			}
			index--;
			flag = 0;
		}
	}
	if (flag)
	{
		cout << "该元素不存在" << endl;
	}
}
//检查容量
void SeqList::Check()
{
	if (ptr == nullptr || index == capacity)
	{
		int new_capcaity = (ptr == nullptr ? 4 : capacity * 2);
		//转移数据
		if (capacity != new_capcaity && capacity != 0)
		{
			int* temp = new int[new_capcaity];
			for (int i = 0; i < index; i++)
			{
				temp[i] = ptr[i];
			}
			delete[] ptr;
			ptr = temp;
			assert(ptr);
			capacity = new_capcaity;
			return;
		}
		ptr = new int[new_capcaity];
		capacity = new_capcaity;
		assert(ptr);
	}
}

2.2 test.cpp(测试,入口)

cpp 复制代码
//test.cpp
#include"SeqList.h"
int main()
{
	SeqList a;
	a.PushBack(1);
	a.PushBack(2);
	a.PushBack(3);
	a.PushBack(4);
	a.PushBack(5);
	a.PushBack(6);
	a.PushBack(1);
	a.Print();
	a.PopBack();
	a.PopBack();
	a.PopBack();
	a.PopBack();
	a.Print();
	a.PushFront(1);
	a.PushFront(2);
	a.PushFront(9);
	a.Print();
	a.PopFront();
	a.Print();
	a.Insert(3, 7);
	cout<<a.Find(2)<<endl;
	cout<<a.Find(8)<<endl;
	a.Print();
	a.Insert(1, 8);
	a.Print();
	a.Erase(1);
	a.Print();
	a.Erase(1);
	return 0;
}
相关推荐
码破苍穹ovo8 分钟前
二分查找----1.搜索插入位置
数据结构·算法
十年编程老舅14 分钟前
C/C++ 高频八股文面试题1000题(一)
c++·八股文·大厂面试题·c++八股文·八股文面试题·c++面经
DBWYX19 分钟前
PHP is the best language.
开发语言·php
何朴尧38 分钟前
全局数据的处理
开发语言
Web极客码40 分钟前
如何在中将网络改为桥接模式并配置固定IP地址
开发语言·网络·ubuntu·php·虚拟机
T风呤1 小时前
QT历史版本,5.15.2使用清华源半小时安装速成
开发语言·qt
Hat_man_1 小时前
Windows下memcpy_s如何在Linux下使用
linux·c++
晨曦5432102 小时前
针对经济学大数据的 Python 爬虫实践指南
开发语言·爬虫·python
上位机付工2 小时前
C#上位机实现报警语音播报
开发语言·c#·上位机·plc·运动控制卡·语音播报·报警播报
千千道2 小时前
QT 中使用 QSettings 读写 ini 配置文件
开发语言·qt