跳表及其实现
参考https://zhuanlan.zhihu.com/p/339750543
| import java.util.Objects; |
| import java.util.Random; |
| import java.util.Stack; |
| |
| |
| |
| |
| public class SkipListPractice { |
| static class SkipNode<T>{ |
| SkipNode<T> right; |
| SkipNode<T> down; |
| int key; |
| T value; |
| public SkipNode(int _key,T _value){ |
| key = _key; |
| value = _value; |
| } |
| } |
| |
| |
| |
| |
| |
| |
| |
| static class SkipList<T>{ |
| SkipNode<T> head; |
| int currentHighestLevel; |
| Random random; |
| final int MAX_LEVEL = 32; |
| public SkipList(){ |
| head = new SkipNode<T>(-1, null); |
| random = new Random(); |
| currentHighestLevel = 0; |
| } |
| public void put(int key,T value){ |
| SkipNode<T> searchResult = search(key); |
| if (Objects.nonNull(searchResult)){ |
| |
| return; |
| } |
| Stack<SkipNode<T>> stack = new Stack<>(); |
| |
| |
| |
| SkipNode<T> pointer = head; |
| while(pointer != null){ |
| if (pointer.right == null || pointer.right.key > key){ |
| stack.add(pointer); |
| pointer = pointer.down; |
| }else{ |
| pointer = pointer.right; |
| } |
| } |
| int level = 1; |
| SkipNode<T> downNode = null; |
| while (!stack.isEmpty()){ |
| |
| pointer = stack.pop(); |
| SkipNode<T> tempNode = new SkipNode<>(key, value); |
| tempNode.down = downNode; |
| downNode = tempNode; |
| |
| tempNode.right = pointer.right; |
| pointer.right = tempNode; |
| if (level > MAX_LEVEL){ |
| break; |
| } |
| double num = random.nextDouble(); |
| if (num > 0.5){ |
| |
| break; |
| } |
| level++; |
| if (level > currentHighestLevel){ |
| |
| currentHighestLevel = level; |
| SkipNode<T> highHeadNode = new SkipNode<T>(-1, null); |
| highHeadNode.down = head; |
| head = highHeadNode; |
| stack.add(highHeadNode); |
| |
| |
| } |
| } |
| } |
| public SkipNode<T> search(int key){ |
| SkipNode<T> pointer = this.head; |
| boolean ifFirst = true; |
| while(pointer != null){ |
| if (pointer.key == key && !ifFirst){ |
| return pointer; |
| }else if(pointer.right == null || pointer.right.key > key){ |
| pointer = pointer.down; |
| }else{ |
| pointer = pointer.right; |
| } |
| ifFirst = false; |
| } |
| return null; |
| } |
| |
| public void delete(int key){ |
| SkipNode<T> pointer = head; |
| while(pointer != null){ |
| if (pointer.right == null || pointer.right.key > key){ |
| pointer = pointer.down; |
| }else if (pointer.right.key == key){ |
| |
| |
| |
| pointer.right = pointer.right.right; |
| pointer = pointer.down; |
| }else{ |
| pointer = pointer.right; |
| } |
| } |
| } |
| |
| public void printList(){ |
| SkipNode<T> pointer = head; |
| int index = 1; |
| SkipNode<T> lowestNode = head; |
| while(lowestNode.down != null){ |
| lowestNode = lowestNode.down; |
| } |
| while(pointer != null){ |
| SkipNode<T> enumNode = pointer.right; |
| SkipNode<T> enumLast = lowestNode.right; |
| System.out.printf("%-8s",index+"head->"); |
| |
| |
| |
| |
| while(enumLast != null && enumNode != null){ |
| if (enumLast.key == enumNode.key){ |
| System.out.printf("%-5s",enumLast.key+"->"); |
| enumNode = enumNode.right; |
| enumLast = enumLast.right; |
| }else{ |
| enumLast = enumLast.right; |
| System.out.printf("%-5s",""); |
| } |
| } |
| pointer = pointer.down; |
| index++; |
| System.out.println(); |
| } |
| } |
| } |
| |
| |
| |
| public static void main(String[] args) { |
| SkipList<Integer> skipList = new SkipList<>(); |
| for (int i = 0;i < 30;i++){ |
| skipList.put(i,324); |
| } |
| skipList.printList(); |
| System.out.println("删除后:"); |
| skipList.delete(5); |
| skipList.delete(0); |
| skipList.delete(10); |
| skipList.printList(); |
| } |
| } |
| |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
2022-08-08 网站部署杂谈