当前位置: 首页 > news >正文

C++数据结构和算法:链表

Q. 有序表和无序表(Hash表)区别?Key有无序的区别。

Q. map 和 set 区别:有无伴随数据的区别。

有序表:红黑树、AVL树、size-banlance-tree、跳表都是有序表

 哈希表:基础类型,值传递;非基础类,必须提供比较器,引用传递。

 

【经典题目】反转链表。要求实现单链表、双链表结构,迭代和递归两种方式。

 1 //迭代
 2 ListNode* ReverseList(ListNode* head)
 3 {
 4     ListNode* prev = nullptr;
 5     ListNode* curr = head;
 6     while (curr)
 7     {
 8         ListNode* next = curr->next;
 9         curr->next = prev;
10         prev = curr;
11         curr = next;
12     }
13     return prev;
14 }
 1 //递归
 2 ListNode* ReverseList(ListNode* head)
 3 {
 4     if (!head || !head->next)
 5         return head;
 6 
 7     ListNode* newHead = ReverseList(head->next);
 8     head->next->next = head;
 9     head->next = nullptr;
10 
11     return newHead;
12 }

 

快慢指针

两个指针p1,p2,p1每次+1,p2每次+2,直到越界前。

Q. 用链表做荷兰国旗问题

思路:准备6个指针,SH指向小于num的头,ST指向小于num的尾;EH指向等于num的头结点,ET指向等于num的尾结点;MH指向大于num的头结点,MT指向大于num的尾结点。

 

Q. 复制含有随机指针节点的链表

1 class Node{
2     int value;
3     Node next;
4     Node rand;
5     Node(int val){
6         value = val;
7     }    
8 }
http://www.wxhsa.cn/company.asp?id=5026

相关文章:

  • CAI:开源网络安全AI框架,打造自主安全测试智能体
  • GAS中,负责封装技能所影响的目标数据(如 Actor、位置、碰撞结果等)-FGameplayAbilityTargetData
  • 详细介绍:Maven入门_简介、安装与配置
  • 实用指南:立体校正原理
  • train-labels.idx1-ubyte里是什么
  • 滑动窗口最大值-leetcode
  • 创建预测窗口-ScopedPredictionWindow();
  • 95. 不同的二叉搜索树 II
  • lc1028-从先序遍历还原二叉树
  • P12558 [UOI 2024] Heroes and Monsters 题解
  • 加把劲——2025 年中总结
  • Ability-GetCurrentActorInfo()-IsLocallyControlled()和APawn::IsLocallyControlled()
  • 应该遵守的代码规范与读《数学之美》有感
  • AbilitySystemComponent和AbilityTask
  • AT_arc171_c [ARC171C] Swap on Tree
  • 202509_QQ_冷门的Base家族
  • SpawnActorDeferred()和SpawnActorOfClass()
  • 【QT】信号和槽
  • 学习日报|线程池专题学习总结 - 详解
  • 如何设计业务架构 - 智慧园区
  • snmp协议
  • 刷题复习(四)二分搜索
  • aardio | 通过点击checkbox复选框本身判断是否勾选
  • 项目介绍
  • 新媒体运营用AI排版工具|10分钟搞定公众号图文的全流程指南
  • 练习第一天学习的内容
  • 常见小错误 FREQUENTLY MADE MISTAKES IN OI
  • ctf工具整理
  • 力扣39题 组合总和
  • 250915 jave se简单过完一遍