蓝桥杯国赛备赛复习——数据结构

一、链表

1.1 单链表
java 复制代码
package 链表;

public class 单链表 {
	static int e[] = new int[11010]; // index号节点的value值(value)
	static int ne[] = new int[11010];// index号节点的下一个节点的index(nextNode)
	static int head=-1,idx=0;      // 头节点的index,当前可用的最小index
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		// 遍历单链表
		for(int i=head;i!=-1;i = ne[i]) {
			System.out.print(e[i]);
		}
	}
	//	插入------链头
	static void add_to_head(int x) {
		e[idx] = x; ne[idx] = head; head = idx; idx++;
	}
    //	插入------第k个节点之后
	static void add_afterK(int k,int x) {
		e[idx] = x; ne[idx] = ne[k]; ne[k] = idx; idx++;
	}
	//  删除------第k个节点之后节点
	static void remove(int k,int x) {
		ne[k] = ne[ne[k]];
	}
}

例题: B3631 单向链表 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

java 复制代码
import java.util.*;
public class Main {
	static int e[] = new int[11011];
	static int en[] = new int[11011];
	static int head = 0,idx = 1;
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner in = new Scanner(System.in);
		e[0] = 1; en[0] = -1;
		int q = in.nextInt();
		while(q--!=0) {
			int o = in.nextInt();
			if(o==1) {
				int x = in.nextInt();
				int y = in.nextInt();
				add(x,y);
			}else if(o==2) {
				int x = in.nextInt();
				int index = find_index(x);
				if(en[index]==-1) {
					System.out.print("0\n");
				}else {
					System.out.print(e[en[index]]+"\n");
				}
			}else {
				int x = in.nextInt();
				remove(x);
			}
		}
	}
	static void add(int x,int y) {
		x = find_index(x);
		e[idx] = y;
		en[idx] = en[x];
		en[x] = idx;
		idx++;
	}
	static void remove(int x) {
		x = find_index(x);
		en[x] = en[en[x]];
	}
	static int find_index(int x) {
		for(int i=head;i!=-1;i = en[i])
			if(e[i]==x)
				return i;
		return -1;
	}
}

这个代码会有三个数据超时,应该改成快读就行了。

1.12双向链表
java 复制代码
package 链表;

public class 双链表 {
	static int e[] = new int[11010]; // index号节点的value值(value)
	static int l[] = new int[11010];// index号节点的左边节点的index
	static int r[] = new int[11010];// index号节点的右边节点的index
	static int idx = 2;
	public static void main(String[] args) {
		// TODO Auto-generated method stub

	}
	// 初始化
	static void init() {
		r[0] = 1; l[1] = 0;
	}
	// K的右边插入x
	static void add_afterK(int k,int x) {
		e[idx] = x;
		l[idx] = k;
		r[idx] = r[k];
		l[r[k]] = idx;
		r[k] = idx;
	}
	// K的左边插入x
	static void add_beforeK(int k,int x) {
		add_afterK(l[k],x);
	}
	//  删除------第k个节点
	static void remove(int k) {
		r[l[k]] = r[k];
		l[r[k]] = l[k];
	}
}

二、栈和队列

2.1 单调栈
2.2 单调队列

三、KMP

相关推荐
Zhan8611242 小时前
数据接口的序列号机制与丢包检测:西班牙行情数据IBEX指数实时行情接入笔记
大数据·数据结构·笔记·区块链
退休倒计时11 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
2601_9618752412 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
dtq042414 小时前
C语言刷题数组5,6(求平均值,求最大值)
c语言·数据结构·算法
洛水水15 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
Coder-magician16 小时前
《代码随想录》刷题打卡day15:二叉树part05
数据结构·c++·算法
Darling噜啦啦16 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
Irissgwe16 小时前
算法的时间复杂度和空间复杂度
数据结构·c++·算法·c·时间复杂度·空间复杂度
qq_2975746717 小时前
设计模式系列文章(基础篇第22篇):访问者模式——分离数据结构与操作,实现灵活扩展
数据结构·设计模式·访问者模式
云淡风轻~窗明几净17 小时前
角谷猜想的任意算法测试
数据结构·人工智能·算法