1
0
mirror of https://github.com/Didnelpsun/CS408.git synced 2026-02-06 04:14:28 +08:00
Files
CS408/Code/CPP-Code/head/static_link_list.h
Didnelpsun 94c62a2082 更新
2021-10-23 23:25:29 +08:00

155 lines
3.0 KiB
C++

#include "head.h"
class StaticLinkListNode {
private:
// 数据元素
element_type _data{};
// 下一个元素的数组下标
int _next{};
public:
// 设置元素
bool SetData(element_type elem);
// 获取元素
element_type GetData() const;
// 设置下标
bool SetNext(int index);
// 获取下标
int GetNext() const;
// 构造函数
StaticLinkListNode();
explicit StaticLinkListNode(element_type elem);
StaticLinkListNode(element_type elem, int next);
// 销毁
bool Destroy();
};
bool StaticLinkListNode::SetData(element_type elem) {
this->_data = elem;
return true;
}
element_type StaticLinkListNode::GetData() const {
return this->_data;
}
bool StaticLinkListNode::SetNext(int index) {
this->_next = index;
return true;
}
int StaticLinkListNode::GetNext() const {
return this->_next;
}
StaticLinkListNode::StaticLinkListNode() {
this->SetData(DEFAULTELEM);
this->SetNext(-1);
}
StaticLinkListNode::StaticLinkListNode(element_type elem) {
this->SetData(elem);
this->SetNext(-1);
}
StaticLinkListNode::StaticLinkListNode(element_type elem, int next) {
this->SetData(elem);
this->SetNext(next);
}
bool StaticLinkListNode::Destroy() {
this->SetData(DEFAULTELEM);
this->SetNext(0);
return true;
}
class StaticLinkList {
private:
// 首元素地址
int _first{};
// 数据长度
int _length{};
// 数据当前最大长度
int _max_size{};
public:
// 数据
StaticLinkListNode *data;
// 设置首元素地址
bool SetFirst(int first);
// 获取首元素地址
int GetFirst() const;
// 数据长度自加
bool SetLength();
// 设置数据长度
bool SetLength(int length);
// 获取数据长度
int GetLength() const;
// 设置数据当前最大长度
bool SetMaxSize(int max_size);
// 获取数据当前最大长度
int GetMaxSize() const;
// 构造函数
StaticLinkList();
StaticLinkList(int first, element_type elem);
};
bool StaticLinkList::SetFirst(int first) {
this->_first = first;
return true;
}
int StaticLinkList::GetFirst() const {
return this->_first;
}
bool StaticLinkList::SetLength() {
this->_length++;
return true;
}
bool StaticLinkList::SetLength(int length) {
this->_length = length;
return true;
}
int StaticLinkList::GetLength() const {
return this->_length;
}
bool StaticLinkList::SetMaxSize(int max_size) {
this->_max_size = max_size;
return true;
}
int StaticLinkList::GetMaxSize() const {
return this->_max_size;
}
StaticLinkList::StaticLinkList() {
this->SetFirst(DEFAULTELEM);
this->SetLength(0);
this->SetMaxSize(MAXSIZE);
this->data = new StaticLinkListNode[MAXSIZE];
}
StaticLinkList::StaticLinkList(int first, element_type elem) {
this->SetFirst(first);
this->SetLength(1);
this->SetMaxSize(MAXSIZE);
this->data = new StaticLinkListNode[MAXSIZE];
this->data[first].SetData(elem);
this->data[first].SetNext(-1);
}