私の連絡先情報
郵便メール:
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
目次
(3). シーケンステーブルの挿入と削除(静的割り当てを例にします)(サンプルコードには必要な基本的な関数が含まれています)
線形テーブル:
(1).その中の各要素、同じデータ型。
(2).要素間、順番に。
(3) すべて。ヘッダー要素そして末尾要素。
(4).ヘッダーとフッターを除き、各要素ごとに 1 つずつ見つかります。直接前駆体そして直接の後継者。
テーブルゼロから
初期化リスト(&L):初期化線形テーブル
リストを破棄(&L):破壊する
。
リスト挿入(&L, i, e):入れる、テーブル L の i 番目の位置に要素 e を挿入します。
リスト削除(&L, i, &e):消去、テーブル L の i 番目の要素を削除し、e を使用して削除された要素を返します。
。
LocateElem(L, e): を押します価値検索、テーブル内の特定のキーワード e の要素を見つけ、添え字ではなく e の順序を返します。
GetElem(L, i): を押します。少しテーブル内の i 番目の要素の値を検索して取得します。
。
その他の一般的な操作:
長さ(L): 検索テーブルリーダー過ごす
印刷リスト(L):出力テーブル全て要素
空(L):判定テーブル空いてますか?、trueまたはfalseを返します
高度に要約された、つまり売上の作成と追加、削除、変更、確認
による順次ストレージデータの線形表
- #define MAX 10
- //顺序表(静态分配)
- class SqList
- {
- public:
- int data[MAX];
- int length;
- };
- //初始化
- void InitList(SqList &l)
- {
- for(int i = 0 ;i < 10 ;i++)
- {
- l.data[i] = 0;
- }
- l.length = 0;
- }
- //打印所有元素
- void PrintList(SqList &l)
- {
- for (int i = 0; i < 10; i++)
- cout << "第" << i << "个数:" << l.data[i] << endl;
- }
-
- //测验
- void test01()
- {
- SqList l;
- InitList(l);
- PrintList(l);
- }
- #define InitSize 10
- //顺序表(动态分配)
- class SqList
- {
- public:
- int* data; //指示动态分配数组的指针
- int MaxSize; //指示最大容量
- int length; //指示当前长度
- };
- //初始化顺序表
- void InitList(SqList& l)
- {
- l.data = new int[InitSize];
- l.MaxSize = InitSize;
- l.length = 0;
- for (int i = 0; i < l.MaxSize; i++)
- {
- l.data[i] = 0;
- }
- }
- //增长数组空间
- void IncreaseSize(SqList& l, int len)
- {
- int* p = l.data; //暂存原数组中的数据
- l.data = new int[10 + len]; //扩展新的数组
- for (int i = 0; i < l.length; i++) //将原数据拷贝进新数组中
- {
- l.data[i] = p[i];
- }
- l.MaxSize = InitSize + len; //修改数组的状态数据
- delete p; //将p释放
- }
- //打印所有元素
- void PrintList(SqList& l)
- {
- for (int i = 0; i < 10; i++)
- cout << "第" << i << "个数:" << l.data[i] << endl;
- }
-
- void test01()
- {
- SqList l;
- InitList(l);
- PrintList(l);
- }
//入れる
bool ListInsert(SqList& l, int d, int e)
{
if (l.length >= MAX) //まず、テーブルがいっぱいかどうか、および挿入が正当であるかどうかを判断します。
{
cout << "挿入に失敗しました。上限に達しました" << endl;
false を返します。
}
(d < 1 || d > l.length + 1)の場合
{
cout << "挿入に失敗しました。直接の先行者がありません" << endl;
false を返します。
}
for (int j = l.length; j >= d; j--) //挿入ポイントの後の要素を後方に移動します
l.data[j] = l.data[j - 1];
l.data[d - 1] = e; //挿入、d は数値を参照するため、配列変換では 1 を減算する必要があります。
l.長さ++;
true を返します。
}//消去
bool ListDelete(SqList& l, int d, int &e)
{
if (d < 1 || d >l.length) //削除された位置が正当かどうかを判断します
false を返します。
e = l.data[d - 1]; //削除された要素を一時的に保存します
for (int j = d; j < l.length; j++) //削除された要素の後の要素を前方に移動します
l.data[j - 1] = l.data[j]; //ここでは j = d でなければなりません、j-1 は j でカバーされます、j = d-1 の場合、次のカバレッジは j がカバーされますj+1 でカバーし、最終的に j+1 がアレイの最大容量を超える可能性があります
l.長さ--;
true を返します。
}
サンプルコード
- #define MAX 10
- //顺序表(静态分配)
- class SqList
- {
- public:
- int data[MAX];
- int length;
- };
- //初始化
- void InitList(SqList& l)
- {
- for (int i = 0; i < 10; i++)
- {
- l.data[i] = 0;
- }
- l.length = 0;
- }
- //打印所有元素
- void PrintList(SqList& l)
- {
- for (int i = 0; i < 10; i++)
- cout << "第" << i << "个数:" << l.data[i] << endl;
- }
- //存入数据
- void InputElem(SqList& l, int e)
- {
- int i = 0;
- while (i < MAX)
- {
- if (l.data[i] == 0)
- {
- l.data[i] = e;
- l.length++;
- break;
- }
- i++;
- }
- }
- //获取顺序表长度
- int GetLength(SqList l)
- {
- //cout << l.length << endl;
- return l.length;
- }
- //插入
- bool ListInsert(SqList& l, int d, int e)
- {
- if (l.length >= MAX) //首先要判断表是否已满、插入是否合法
- {
- cout << "插入失败,已达上限" << endl;
- return false;
- }
-
- if (d < 1 || d > l.length + 1)
- {
- cout << "插入失败,无直接前驱" << endl;
- return false;
- }
- for (int j = l.length; j >= d; j--) //将插入点之后的元素后移
- l.data[j] = l.data[j - 1];
- l.data[d - 1] = e; //插入,因为d指的是第几个数,在数组的换算中要减一
- l.length++;
- return true;
- }
- //删除
- bool ListDelete(SqList& l, int d, int &e)
- {
- if (d < 1 || d >l.length) //判断删除的位置是否合法
- return false;
- e = l.data[d - 1]; //暂存删除掉的元素
- for (int j = d; j < l.length; j++) //将被删除元素之后的元素前移
- l.data[j - 1] = l.data[j]; //此处,必须是j = d,j-1被j覆盖,若j = d-1,则下文的覆盖会变为j 被j+1 覆盖,而j+1在最后有可能会超过数组的最大容量
- l.length--;
- return true;
- }
-
- //查看情况
- void CheckList(SqList& l)
- {
- PrintList(l);
- cout << "当前长度为" << GetLength(l) << endl;
- }
-
- //测验
- void test01()
- {
- SqList l;
- InitList(l);
-
- //输入部分数据
- InputElem(l, 1);
- InputElem(l, 2);
- InputElem(l, 3);
- InputElem(l, 4);
- CheckList(l);
-
- //开始插入
- if(ListInsert(l, 3, 6))
- CheckList(l);
-
- //开始删除
- int a = -1;
- if (ListDelete(l, 2, a))
- CheckList(l);
- }
非常にシンプルなので、詳細を説明する必要はありません
- //判断d的合法性
- bool JugdeD(SqList l, int d)
- {
- if (d < 1 || d > l.length)
- return false;
- return true;
- }
-
- //按位序查找
- int GetElem(SqList l, int d)
- {
- if (JugdeD(l, d))
- return l.data[d - 1];
- return 0;
- }
-
- //按值查找
- int LocateElem(SqList l, int e)
- {
- for (int i = 0; i < l.length; i++)
- {
- if (l.data[i] == e) //数组储存的数据,若是类等复杂的数据类型,则需要对等号进行重载
- return i + 1;
- }
- return 0;
- }
- //其余代码与上文相同
- //其中,JugdeD函数可以替换上文插入与删除中对位序合法性的判别————封装
によるチェーンストレージデータの線形表
- //单链表
- class LNode
- {
- public:
- int data; //数据域,存放数据
- LNode* next; //指针域,指向下一个节点
- };
- //用using关键字给类起别名,用LinkList指代的是头结点,代表的是整个链表
- using LinkList = LNode*;
-
- //初始化
- bool InitList(LinkList& L)
- {
- L = new LNode();
- if (L == nullptr) //如果成立,则说明内存不足,分配失败
- return false;
- L->next = nullptr;
- return true;
- }
ヘッド ノードがない場合は、ヘッド ポインタの変化に注目してください。他はすべて同じです。
インサート(通常版)
- //插入
- bool ListInsert(LinkList& L, int i, int e)
- {
- if (i < 1) //判断插入位点是否合法[1]——i值的合法性
- {
- cout << "i为负数" << endl;
- return false;
- }
- LNode* p = L; //让p与L指向相同的位点,L是指示头指针的,所以L是不能改变的
- LNode* s = new LNode(); //新的数据储存
- s->data = e;
- while (p != nullptr && i != 1) //由头结点起始,开始遍历寻找对应位点
- {
- p = p->next;
- i--;
- }
- if (p == nullptr) //判断插入的位点是否合法[2]——i值对应的节点的合法性
- {
- cout << "插入位点超出实际长度" << endl;
- return false;
- }
- s->next = p->next; //开始接轨,顺序不能乱
- p->next = s;
- return true;
- }
インサート(パッケージ版)
- //特定节点的后插操作
- bool InsertNextNode(LNode* p, int e)
- {
- if (p == nullptr)
- {
- cout << "插入位点超出实际长度" << endl;
- return false;
- }
- LNode* s = new LNode();
- s->data = e;
- s->next = p->next;
- p->next = s;
- return true;
- }
- //插入
- bool ListInsert(LinkList& L, int i, int e)
- {
- if (i < 1) //判断插入位点是否合法[1]——i值的合法性
- {
- cout << "i为负数" << endl;
- return false;
- }
- LNode* p = L; //让p与L指向相同的位点,L是指示头指针的,所以L是不能改变的
- while (p != nullptr && i != 1) //由头结点起始,开始遍历寻找对应位点
- {
- p = p->next;
- i--;
- }
- return InsertNextNode(p, e); //被封装了的部分
- }