C++ 向量、列表和队列的使用详解

c++++ 中,向量用于快速随机访问和高效内存管理,列表用于高效插入和删除操作,队列用于遵循先进先出原则处理数据。具体应用包括以向量存储学生信息,以列表存储购物清单,以队列模拟银行队列。

C++ 向量、列表和队列的使用详解

C++ 向量、列表和队列的使用详解

简介

在 C++ 中,向量、列表和队列是三种基本的数据结构,每种都有自己的独特优点和用例。在这篇文章中,我们将深入探讨这三种数据结构的使用,并通过实战案例来演示它们的应用。

立即学习“C++免费学习笔记(深入)”;

向量

向量是一个动态数组,允许我们存储指定类型的一组元素。使用向量非常方便,因为它提供了快速的随机访问和高效的内存管理。

使用

#include int main() {  vector myVector;  // 创建一个空的向量  myVector.push_back(10);  // 向向量中添加元素  myVector.push_back(20);  cout << "容量: " << myVector.capacity() << endl;  // 获取向量的容量  cout << "大小: " << myVector.size() << endl;  // 获取向量的大小  return 0;}

列表

列表是一种双向链表,提供了高效的插入和删除操作。它使用节点来存储数据,每个节点都包含元素值和指向下一个节点的指针。

使用

#include int main() {  list myList;  // 创建一个空列表  myList.push_back(10);  // 向列表尾部添加元素  myList.push_front(5);  // 向列表头部添加元素  list::iterator it = myList.begin();  // 获取列表的迭代器  it = myList.erase(it);  // 删除列表中的第一个元素   return 0;}

队列

队列是一种遵循先进先出 (FIFO) 原则的数据结构。它允许我们从队列尾部添加元素,并从队列头部移除元素。

使用

#include int main() {  queue myQueue;  // 创建一个空队列  myQueue.push(10);  // 向队列尾部添加元素  myQueue.push(20);  cout << "队列大小: " << myQueue.size() << endl;  // 获取队列的大小  cout << "队列头元素: " << myQueue.front() << endl;  // 获取队列头的元素  myQueue.pop();  // 从队列头部移除元素  return 0;}

实战案例

使用向量存储学生信息

#include class Student {public:  int id;  string name;};int main() {  vector students;  // 创建一个存储 Student 对象的向量  // 添加一些学生信息  students.push_back({1, "John Doe"});  students.push_back({2, "Jane Smith"});  // 遍历向量并打印学生信息  for (const Student& student : students) {    cout << "ID: " << student.id << ", Name: " << student.name << endl;  }  return 0;}

使用列表存储购物清单

#include int main() {  list shoppingList;  // 创建一个存储字符串的列表  // 添加一些物品到购物清单  shoppingList.push_back("牛奶");  shoppingList.push_back("面包");  shoppingList.push_back("鸡蛋");  // 删除列表中的第二个物品  list::iterator it = shoppingList.begin();  advance(it, 1);  shoppingList.erase(it);  // 遍历列表并打印购物清单  for (const string& item : shoppingList) {    cout << item << endl;  }  return 0;}

使用队列模拟银行队列

#include int main() {  queue bankQueue;  // 创建一个存储整数的队列  // 模拟客户加入银行队列  bankQueue.push(1);  bankQueue.push(2);  bankQueue.push(3);  // 处理队列中第一个客户  int customerNumber = bankQueue.front();  bankQueue.pop();  cout << "处理的客户编号: " << customerNumber << endl;  return 0;}

以上就是C++ 向量、列表和队列的使用详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1458220.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 10:23:48
下一篇 2025年12月9日 18:12:50

相关推荐

  • C++ lambda 表达式在异步编程中的优势是什么?

    在异步编程中,c++++ lambda 表达式提供以下优势:简化回调处理:允许定义简洁的回调,保持代码整洁。封装复杂逻辑:封装相关逻辑,提高代码可读性和可维护性。捕获变量:捕获作用域变量,避免异步操作中“use-after-free”错误。线程安全:在并发环境中安全使用,简化异步代码编写。 C++ …

    2025年12月18日
    000
  • C++ lambda 表达式在算法设计中的常见做法是什么?

    lambda 表达式在 c++++ 算法设计中很常见,因为它可以简化匿名函数对象,使算法更易读和更高效。其常见用法包括:定义比较函数,以便为算法指定不同的比较标准。使用 std::function 将 lambda 转换为仿函数,以便与需要仿函数的算法一起使用。编写自定义迭代器规则,实现更灵活和可读…

    2025年12月18日
    000
  • C++ 函数库与第三方库的比较

    标准模板库 (stl) 和第三方库为 c++++ 提供了广泛的可用功能。stl 提供基本数据结构和算法,而第三方库提供了更高级的功能,例如并发和图形。stl 是随 c++ 标准化的,提供可靠性和稳定性,而第三方库的标准化和稳定性可能因库而异。在许可方面,stl 通常在 apache license …

    2025年12月18日
    000
  • C++ 自身函数详解及应用:const 修饰符如何保证数据完整性?

    const 修饰符通过以下方式确保数据的完整性:常量:声明不可修改的常数值,防止意外覆盖。引用:表示引用的变量不可修改,保护原始变量。函数参数:声明为输入参数,在函数内不能修改。成员函数:声明为只读函数,不会修改对象成员变量。 C++ 自身函数详解及应用:const 修饰符如何保证数据完整性? 简介…

    2025年12月18日
    000
  • 如何使用 C++ lambda 表达式简化代码?

    使用 c++++ lambda 表达式可以简化代码:lambda 表达式允许创建匿名函数,可捕获外部变量。lambda 表达式的语法为:[capture_list](parameters) -> return_type { body },其中 capture_list 捕获外部变量,param…

    2025年12月18日
    000
  • C++ lambda 表达式中的内存管理策略

    lambda 表达式中,引用捕获使外部变量保持有效;值捕获则复制外部变量副本,与外部变量生命周期无关。例如,引用捕获 lambda 延迟计算一个变量的和,即使列表调用已更改,lambda 仍会使用原始变量;值捕获 lambda 确保线程安全,每个并发线程获得不同副本。 C++ Lambda 表达式中…

    2025年12月18日
    000
  • C++ 标准模板库的应用案例解析

    c++++ 标准模板库 (stl) 是一组功能强大的数据结构和算法,可简化复杂数据的操作。容器:存储和组织数据,包括数组、链表、集合和映射。算法:对容器中的元素执行操作,例如排序、搜索、转换和累加。实战案例:联系人管理系统:使用容器存储联系人,使用算法搜索和删除联系人。结论:stl 简化了数据操作,…

    2025年12月18日
    000
  • C++ lambda 表达式如何优化性能?

    优化 c++++ lambda 表达式性能的方法包括:使用 [=] 捕获列表指定要捕获的变量,以避免不必要的复制。使用 lambda::expires_after 在特定时间后使 lambda 表达式无效,以防止内存泄漏。避免创建不必要的 lambda 表达式,改用内联函数或其他技术。优化捕获的变量…

    2025年12月18日
    000
  • C++ 自身函数详解及应用:如何使用模板函数实现代码重用?

    使用模板函数实现代码重用:模板函数允许您编写通用的代码,可用于不同的数据类型。模板函数语法包括一个类型参数,可替换为任何数据类型。调用模板函数时,编译器会自动为每个数据类型实例化函数。实战案例:模板函数可用于编写一个通用的函数,以计算不同数据类型和长度数组的长度。 C++ 自身函数详解及应用:使用模…

    2025年12月18日
    000
  • C++ 自身函数详解及应用:std::variant 类如何替代异构联合?

    std::variant 类取代了异构联合,提供了类型安全、易读性和灵活性:强制类型检查以防止错误访问(类型安全)。提高代码可读性和自解释性。支持存储任何类型对象,包括自定义类型和 lambda 表达式。 std::variant:替代异构联合的强类型选择 引言 C++ 中的异构联合是一种允许存储不…

    2025年12月18日
    000
  • C++ 函数库和标准模板库的区别是什么?

    c++++ 函数库和 stl 的主要区别在于:函数库包含预定义函数,执行特定任务;stl 提供泛型容器和算法。函数库由用户创建或来自第三方库,而 stl 是 c++ 标准库的一部分。函数库需要单独包含,而 stl 不需要包含。 C++ 函数库与标准模板库 (STL) 的区别 在 C++ 编程中,函数…

    2025年12月18日
    000
  • C++ 自身函数详解及应用:map 容器如何高效存储键值对?

    在 c++++ 中,map 容器用于高效存储键值对,确保键的唯一性,并提供多种函数来操作和管理其内容,包括插入、删除和查找键值对。 这些函数包括 begin()、end()、clear()、count()、emplace()、erase()、find()、insert() 和 operator[]。…

    2025年12月18日
    000
  • C++ lambda 表达式与模板元编程

    是的,c++++ lambda 表达式与模板元编程(tmp)结合使用时,可创建强大的可扩展代码:lambda 表达式提供匿名函数语法,允许捕获环境并用作值或参数。tmp 允许在编译时执行复杂计算,根据类型信息和编译时常量创建可定制解决方案。结合这两个功能,可以实现动态组合器等实战案例,在运行时从一组…

    2025年12月18日
    000
  • C++ lambda 表达式与普通函数有何区别?

    c++++ lambda 表达式与普通函数的区别:捕获变量:lambda 表达式可以捕获外部作用域变量,而普通函数不能。类型推导:lambda 表达式自动推导出返回类型,而普通函数需要显式声明。参数传递:lambda 表达式隐式捕获周围作用域变量,普通函数显式传递参数。灵活性和可重用性:普通函数更灵…

    2025年12月18日
    000
  • C++ 标准模板库的优化策略和实践

    优化 c++++ stl 的策略包括:选择合适的容器使用迭代器,避免指针操作优先使用移动函数,避免不必要复制使用编译器优化缓存经常访问的数据 C++ 标准模板库的优化策略和实践 简介 C++ 标准模板库 (STL) 是一组功能强大的数据结构和算法,为 C++ 程序员提供了强大的能力。然而,充分利用 …

    2025年12月18日
    000
  • C++ 文件操作函数的全面解读

    c++++ 文件操作函数解读:文件类型:文本/二进制打开模式:r/w/a/rb/wb文件操作函数:fopen/fclose/fread/fwrite/fseek/ftell/feof实战案例:打开文本文件,逐行读取并输出 C++ 文件操作函数的全面解读 文件操作是 C++ 程序设计中必不可少的任务。…

    2025年12月18日
    000
  • C++ 搜索和排序函数的性能比较

    性能最佳的 c++++ 搜索和排序函数:搜索: std::binary_search(o(log n))排序: std::sort(o(n log n)) C++ 搜索和排序函数的性能比较 简介 在许多编程应用中,搜索和排序算法是不可或缺的。C++ 标准库提供了各种各样的搜索和排序函数,涵盖了不同的…

    2025年12月18日
    000
  • C++ lambda 表达式在算法中的应用

    摘要:lambda 表达式可创建匿名函数对象,在算法中可用作仿函数、谓词和操作符重载。应用示例包括使用 lambda 表达式实现排序和筛选算法,从而简化代码并提高可读性。 C++ Lambda 表达式在算法中的应用 Lambda 表达式是 C++ 11 中引入的一种强大的工具,它允许在运行时创建匿名…

    2025年12月18日
    000
  • C++ 函数性能优化中常见的误区与陷阱

    在 c++++ 函数性能优化中,常见的误区包括:过度优化、混淆热路径和冷路径、使用不当的数据结构、滥用内联、不当的内存管理、过早优化以及优化器错误推测。针对这些误区,需优先优化关键代码路径,专注于热路径、选择高效的数据结构、谨慎使用内联、管理内存并避免过早优化,同时理解编译器优化器的限制。 C++ …

    2025年12月18日
    000
  • C++ 函数最佳实践的企业应用案例

    在企业 c++++ 应用程序中,遵守函数最佳实践可提高代码质量和可维护性。这些实践包括:保持函数签名简洁并使用适当的命名约定和数据类型。使函数体简洁,遵循单一职责原则,并使用异常处理来处理错误。明确指定返回值类型,并针对错误条件使用异常或错误代码。将重复性或辅助性任务移至辅助函数,以提高可维护性和重…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信