数据结构——线性表

逻辑结构------线性表

1.线性表的定义(逻辑结构)

要点:

  • 相同数据类型

  • 有限

  • 序列
    几个概念:

  • 是线性表中的"第i个"元素线性表中的位序

  • 是表头元素;是表尾元素。

  • 除第一个元素外,每个元素有且仅有一个直接前驱;除最后一个元素外,每个元素有且仅有一个直接后继

  • ⭐注意:位序从1开始,数组下标从0开始


物理结构------顺序表

顺序表,按数组理解即可。

2.顺序表 (物理结构)

顺序表:用顺序存储的方式实现线性表。

逻辑上相邻的元素 存储在物理位置上也相邻的存储单元中,元素之间的关系由存储单元的邻接关系来体现。


物理结构------链表

什么是链表?

链表是一种通过指针串联在一起的线性结构。

每一个节点由两部分组成,一个是数据域 data ,一个是指针域 next(存放指向下一个节点的指针),最后一个节点的指针域指向null(空指针的意思)。

3.单链表(物理结构)

单链表:每个结点除了存放数据元素外,还要存储指向下一个节点的指针。

单链表中的指针域只能指向节点的下一个节点。

单链表代码:

  • head 表示头结点的下标
  • e[i] 表示结点i的值
  • ne[i] 表示节点i的next指针是多少
  • idx 存储当前已经用到了哪个点

头插法

cpp 复制代码
//头插法
void head_insert(int x){
	e[idx]=x;
	ne[idx]=head;
	head=idx;
	idx++;
} 

一般插入

cpp 复制代码
//在第k个插入的数后插入一个数
void insert(int k,int x){
	//插入的是第k+1个数,下标是k
	 e[idx]=x;
	 ne[idx]=ne[k];
	 ne[k]=idx;
	 idx++;
} 

全部代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e6+6;
int head,e[N],ne[N],idx;
//初始化
void initial(){
	head=-1,idx=1;
} 
//头插法
void head_insert(int x){
	e[idx]=x;
	ne[idx]=head;
	head=idx;
	idx++;
} 

//在第k个插入的数后插入一个数
void insert(int k,int x){
	//插入的是第k+1个数,下标是k
	 e[idx]=x;
	 ne[idx]=ne[k];
	 ne[k]=idx;
	 idx++;
} 
//删除第k个插入的数后面的数
void move(int k){
	//k=0时, 
	if(k==0)
		head=ne[head];
	else
		ne[k]=ne[ne[k]];
} 
int main(){
	int m;
	cin>>m;
	//初始化
	memset(ne,-1,sizeof ne); 
	initial();
	//cout<<ne[1]<<ne[10];
	while(m--){
		char a;
		cin>>a;
		if(a=='H'){
			int x;
			cin>>x;
			head_insert(x);
		}
		else if(a=='I'){
			int k,x;
			cin>>k>>x;
			insert(k,x);
		}
		else{
			//a==D
			int k;
			cin>>k;
			move(k);
		}
	}
	//cout<<ne[15];
	//输出
	for(int i=head;i!=-1;i=ne[i])
	{
		cout<<e[i]<<" ";
	} 
	return 0;
}

4.双链表(物理结构)

双链表:每一个节点有两个指针域,一个指向下一个节点,一个指向上一个节点。

双链表既可以向前查询也可以向后查询。

双链表插入

cpp 复制代码
//在第k个结点的右边插入一个结点
void r_insert(int k,int x){
	e[idx]=x;
	r[idx]=r[k];
	l[idx]=k;
	l[r[k]]=idx;
	r[k]=idx;
	idx++;
}
//在第k个结点的左边插入
void l_insert(int k,int x){
	r_insert(l[k],x); 
} 
//在最右侧插入
void right(int x){
	r_insert(l[1],x);
} 
//在最左侧插入
void left(int x){
	r_insert(0,x);
}

删除

cpp 复制代码
//删除第K个插入的数 
void remove(int k){
	r[l[k]]=r[k];
	l[r[k]]=l[k]; 
}

所有代码

cpp 复制代码
//双链表
#include<bits/stdc++.h>
using namespace std;
const int N=1e6+6;
int l[N],r[N],idx,e[N];
//初始化
void init(){
	r[0]=1;
	l[1]=0;
	idx=2;
} 
//在第k个结点的右边插入一个结点
void r_insert(int k,int x){
	e[idx]=x;
	r[idx]=r[k];
	l[idx]=k;
	l[r[k]]=idx;
	r[k]=idx;
	idx++;
}
//在第k个结点的左边插入
void l_insert(int k,int x){
	r_insert(l[k],x); 
} 
//在最右侧插入
void right(int x){
	r_insert(l[1],x);
} 
//在最左侧插入
void left(int x){
	r_insert(0,x);
} 
//删除第K个插入的数 
void remove(int k){
	r[l[k]]=r[k];
	l[r[k]]=l[k]; 
}

int main(){
	int m;
	cin>>m;
	char op[6];
	int x;
	int k;
	init();
	while(m--){
		scanf("%s",&op);
		if(op[0]=='L'){
			cin>>x;
			left(x);
		}
		else if(op[0]=='R'){
			cin>>x;
			right(x);
		}
		else if(op[0]=='D'){
			cin>>k;
			remove(k+1);
		}
		else if(op[1]=='L'){
			cin>>k>>x;
			l_insert(k+1,x);
		}
		else{
			cin>>k>>x;
			r_insert(k+1,x);
		}
	}
	//output
	for(int i=r[0];i!=1;i=r[i]) {
		cout<<e[i]<<" ";
	}
	return 0;
	
}



 
相关推荐
im_AMBER1 小时前
Leetcode 99 删除排序链表中的重复元素 | 合并两个链表
数据结构·笔记·学习·算法·leetcode·链表
s砚山s2 小时前
代码随想录刷题——二叉树篇(十三)
数据结构·算法
ulias2122 小时前
AVL树的实现
开发语言·数据结构·c++·windows
黎雁·泠崖2 小时前
二叉树知识体系全梳理:从基础到进阶一站式通关
c语言·数据结构·leetcode
蜕变菜鸟2 小时前
JS的Object.keys()和sort()排序的用法
数据结构·算法
镜中人★2 小时前
408数据结构考纲知识点(更新中)
数据结构
杜子不疼.3 小时前
【LeetCode30_滑动窗口 + 哈希表】:三招搞定“串联所有单词的子串”
数据结构·算法·哈希算法
妹妹够啦3 小时前
1. 两数之和
数据结构·算法·leetcode
vyuvyucd3 小时前
Java数组与Arrays类实战指南
数据结构·算法
EXtreme353 小时前
【数据结构】彻底搞懂二叉树:四种遍历逻辑、经典OJ题与递归性能全解析
c语言·数据结构·算法·二叉树·递归