C++开发学习路线03:数据结构与算法篇

本文探讨了C++中的数据结构与算法,包括二叉树的四种遍历方式,哈希表的冲突解决策略,二分查找的编程实现,排序算法的时间复杂度,非递归快速排序,数组拐点的寻找,IP地址查找的字典树方法,以及线程安全队列的设计。
摘要由CSDN通过智能技术生成

0x01数据结构与算法部分(9个问题)

1、 二叉树的四种遍历方式
前序 中序 后序 层序
2、 哈希表工作原理,如何解决哈希冲突?
链地址法:相同的key通过链表相连接
线性探测法:到的哈希地址冲突(该位置上已存储数据)的话 ,我们就是将这个数据插到下一个位置
二次探测法:
哈希函数:除余留数法,平方取中法,关键字法
3、编程实现一个二分查找

bool binearySearch(int target, vector<int>& nums) {
   
    int l=0, r = nums.size() - 1;
    while (l <= r) {
   
        int mid = (l + r) >> 1;
        if (nums[mid] > target) --r;
        else if (nums[mid] < target) ++l;
        else return true;
    }
    return false;
}

4、常用的排序算法,各自的时间复杂度是什么?
常见排序算法的情况如下
在这里插入图片描述
5、快排非递归

    int func(vector<int>& nums,int l
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值