代码随想录八股训练营第三十七天| C++

前言

一、map和unorder_map的区别?

1.1.内部实现:

1.2.排序:

1.3.查找效率:

1.4.内存使用:

1.5.迭代器:

1.6.键的唯一性:

1.7.使用场景:

二、C++11 新特性有哪些?

2.1.std::map:

总结


前言

在现代软件开发中,选择合适的数据结构如 C++ 标准库中的 std::mapstd::unordered_map 对于优化性能和代码可维护性至关重要。同样,C++11 的新特性显著提升了编程的灵活性和效率。


一、map和unorder_map的区别?

在 C++ 标准库中,std::mapstd::unordered_map 都是关联容器,用于存储键值对,但它们在内部实现和性能特性上有所不同。以下是它们的主要区别:

1.1.内部实现:

  • std::map 是基于红黑树实现的,它是一种自平衡的二叉搜索树。
  • std::unordered_map 是基于哈希表实现的。

1.2.排序:

  • std::map 中的元素会根据键自动排序,通常是按照键的升序排列。
  • std::unordered_map 中的元素不会自动排序,元素的顺序是随机的,取决于哈希函数和冲突解决策略。

1.3.查找效率

  • std::map 的查找、插入和删除操作的时间复杂度通常是 O(log n),因为是基于树的结构。
  • std::unordered_map 的查找、插入和删除操作的平均时间复杂度是 O(1),但在最坏情况下(比如哈希冲突很多时)可能会退化到 O(n)。

1.4.内存使用:

  • std::map 通常比 std::unordered_map 使用更多的内存,因为它需要额外的指针来维护树的结构。
  • std::unordered_map 通常使用较少的内存,因为它只需要存储元素和哈希桶。

1.5.迭代器:

  • std::map 的迭代器是双向迭代器,可以向前和向后遍历。
  • std::unordered_map 的迭代器是前向迭代器,只能向前遍历。

1.6.键的唯一性

  • 在 std::map 和 std::unordered_map 中,键都是唯一的,不允许有重复的键。

1.7.使用场景:

  • 当需要有序的键值对,或者需要频繁地进行范围查询时,std::map 是更好的选择。
  • 当需要快速的查找、插入和删除操作,并且不关心元素的顺序时,std::unordered_map 是更好的选择。

二、C++11 新特性有哪些?

C++11 是 C++ 语言的一个重要版本,它在 2011 年被正式批准为 ISO 标准。C++11 引入了许多新特性,旨在提高语言的表达能力、性能和安全性。以下是一些主要的 C++11 新特性:

2.1.std::map:

  • 自动类型推断(auto 关键字): 允许编译器自动推断变量的类型。
  • 范围基于的 for 循环: 提供了一种更简洁和直观的方式来遍历容器。
  • lambda 表达式: 允许在需要的地方定义匿名函数。
  • 智能指针: 引入了了 std::unique_ptr、std::shared_ptr和std::weak_ptr用于自动管理动态分配的内存。
  • 并发编程支持: 引入了入了线程库,包括 std::threadstd::mutexstd::lock 等。
  • 正则表达式: 通过<regex> 头文件提供了正则表达式的支持。
  • 初始化列表: 允许使用花括号 {} 来初始化对象。
  • 强类型枚举(enum class): 引入了强类型枚举,提高了枚举类型的安全性和可读性。
  • 右值引用和移动语义: 引入右值引用(使用 && 表示),支持移动语义,可以提高性能。
  • nullptr: 引入了 nullptr 作为空指针字面量的更安全替代。
  • 统一的初始化(统一的初始化语法): 允许使用花括号 {} 或者圆括号 () 来初始化对象。
  • 类型别名和模板别名(using 声明): 允许使用 using 声明来简化类型名。
  • 继承构造函数: 允许派生类继承基类的构造函数。
  • 委托构造函数: 允许在一个构造函数中调用另一个构造函数。
  • 变长模板参数: 允许模板函数和类接受任意数量的模板参数。
  • 静态断言(static_assert): 允许在编译时进行类型检查。
  • 属性(属性类): 允许定义属性类,用于封装数据和相关的操作。
  • 线程局部存储(thread_local 关键字): 允许定义线程局部变量。
  • 原子操作: 引入了原子类型和原子操作,用于无锁编程。
  • 文件系统库(C++17 引入,但通常与 C++11 一起使用): 提供了文件系统操作的接口。

总结

std::mapstd::unordered_map 根据应用需求的不同,各有优势;而 C++11 的新特性则为开发者提供了强大的工具,以应对各种编程挑战。

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
代码随想录算法训练营是一个优质的学习和讨论平台,提供了丰富的算法训练内容和讨论交流机会。在训练营中,学员们可以通过观看视频讲解来学习算法知识,并根据讲解内容进行刷题练习。此外,训练营还提供了刷题建议,例如先看视频、了解自己所使用的编程语言、使用日志等方法来提高刷题效果和语言掌握程度。 训练营中的讨论内容非常丰富,涵盖了各种算法知识点和解题方法。例如,在第14训练营中,讲解了二叉树的理论基础、递归遍历、迭代遍历和统一遍历的内容。此外,在讨论中还分享了相关的博客文章和配图,帮助学员更好地理解和掌握二叉树的遍历方法。 训练营还提供了每日的讨论知识点,例如在第15的讨论中,介绍了层序遍历的方法和使用队列来模拟一层一层遍历的效果。在第16的讨论中,重点讨论了如何进行调试(debug)的方法,认为掌握调试技巧可以帮助学员更好地解决问题和写出正确的算法代码。 总之,代码随想录算法训练营是一个提供优质学习和讨论环境的平台,可以帮助学员系统地学习算法知识,并提供了丰富的讨论内容和刷题建议来提高算法编程能力。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [代码随想录算法训练营每日精华](https://blog.csdn.net/weixin_38556197/article/details/128462133)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值