一个知识STL

STL(标准模板库)是C++中使用广泛的模板库,它提供了许多常用的数据结构和算法。下面将详细介绍STL中的所有数据类型,并给出一些使用示例。

  1. 容器(Containers):

    • vector:可变大小的动态数组,类似于内置数组,但可以自动调整大小。
    #include <vector>
    using namespace std;
    
    vector<int> nums {1, 2, 3, 4, 5};
    nums.push_back(6); // 添加元素到末尾
    nums.pop_back(); // 删除末尾元素
    
    • list:双向链表,支持高效的插入和删除操作。
    #include <list>
    using namespace std;
    
    list<int> nums {1, 2, 3, 4, 5};
    nums.push_front(0); // 在链表头部插入元素
    nums.pop_front(); // 删除链表头部元素
    
    • deque:双端队列,类似于向量,但可以在头部和尾部进行插入和删除操作。
    #include <deque>
    using namespace std;
    
    deque<int> nums {1, 2, 3, 4, 5};
    nums.push_front(0); // 在头部插入元素
    nums.pop_front(); // 删除头部元素
    nums.push_back(6); // 在尾部插入元素
    nums.pop_back(); // 删除尾部元素
    
    • stack:栈,后入先出(LIFO)的数据结构。
    #include <stack>
    using namespace std;
    
    stack<int> nums;
    nums.push(1); // 入栈
    nums.push(2);
    nums.pop(); // 出栈
    
    • queue:队列,先入先出(FIFO)的数据结构。
    #include <queue>
    using namespace std;
    
    queue<int> nums;
    nums.push(1); // 入队列
    nums.push(2);
    nums.pop(); // 出队列
    
    • priority_queue:优先队列,根据元素的优先级进行排序,每次取出优先级最高的元素。
    #include <queue>
    using namespace std;
    
    priority_queue<int> nums;
    nums.push(3); // 插入元素
    nums.push(1);
    nums.push(2);
    int highest = nums.top(); // 获取优先级最高的元素
    nums.pop(); // 删除优先级最高的元素
    
    • set:有序集合,存储不重复的元素,支持插入、删除和查找操作。
    #include <set>
    using namespace std;
    
    set<int> nums {1, 2, 3, 4, 5};
    nums.insert(6); // 插入元素
    nums.erase(3); // 删除元素
    auto it = nums.find(2); // 查找元素
    
    • multiset:有序多重集合,存储可重复的元素,支持插入、删除和查找操作。
    #include <set>
    using namespace std;
    
    multiset<int> nums {1, 2, 3, 4, 5};
    nums.insert(2);
    nums.erase(3);
    auto range = nums.equal_range(2); // 查找元素的范围
    
    • map:有序键值对,存储唯一的键和对应的值,支持按键进行插入、删除和查找操作。
    #include <map>
    using namespace std;
    
    map<string, int> temperature {{"Monday", 25}, {"Tuesday", 27}, {"Wednesday", 24}};
    temperature["Thursday"] = 26; // 插入键值对
    temperature.erase("Wednesday"); // 删除键值对
    auto it = temperature.find("Tuesday"); // 查找键对应的值
    
    • multimap:有序多重键值对,存储可重复的键和对应的值,支持按键进行插入、删除和查找操作。
    #include <map>
    using namespace std;
    
    multimap<char, int> grades {{'A', 90}, {'B', 80}, {'C', 70}};
    grades.insert(make_pair('B', 75)); // 插入键值对
    grades.erase('C'); // 删除键对应的所有值
    auto range = grades.equal_range('B'); // 查找键对应的值的范围
    
    • unordered_set:无序集合,存储不重复的元素,支持插入、删除和查找操作,内部实现为哈希表。
    #include <unordered_set>
    using namespace std;
    
    unordered_set<int> nums {1, 2, 3, 4, 5};
    nums.insert(6); // 插入元素
    nums.erase(3); // 删除元素
    auto it = nums.find(2); // 查找元素
    
    • unordered_multiset:无序多重集合,存储可重复的元素,支持插入、删除和查找操作,内部实现为哈希表。
    #include <unordered_set>
    using namespace std;
    
    unordered_multiset<int> nums {1, 2, 3, 4, 5};
    nums.insert(2);
    nums.erase(3);
    auto range = nums.equal_range(2); // 查找元素的范围
    
    • unordered_map:无序键值对,存储唯一的键和对应的值,支持按键进行插入、删除和查找操作,内部实现为哈希表。
    #include <unordered_map>
    using namespace std;
    
    unordered_map<string, int> temperature {{"Monday", 25}, {"Tuesday", 27}, {"Wednesday", 24}};
    temperature["Thursday"] = 26; // 插入键值对
    temperature.erase("Wednesday"); // 删除键值对
    auto it = temperature.find("Tuesday"); // 查找键对应的值
    
    • unordered_multimap:无序多重键值对,存储可重复的键和对应的值,支持按键进行插入、删除和查找操作,内部实现为哈希表。
    #include <unordered_map>
    using namespace std;
    
    unordered_multimap<char, int> grades {{'A', 90}, {'B', 80}, {'C', 70}};
    grades.insert(make_pair('B', 75)); // 插入键值对
    grades.erase('C'); // 删除键对应的所有值
    auto range = grades.equal_range('B'); // 查找键对应的值的范围
    
  2. 迭代器(Iterators):

    • 迭代器是STL中通用的遍历和访问容器元素的手段,允许以相同的方式访问不同容器类型。
    • begin():返回指向容器中第一个元素的迭代器。
    • end():返回指向容器中最后一个元素之后位置的迭代器。
    • advance():将迭代器移动指定的距离。
    • distance():计算两个迭代器之间的距离。
    • next():返回指向当前迭代器位置之后指定距离的迭代器。
    • prev():返回指向当前迭代器位置之前指定距离的迭代器。
    #include <iostream>
    #include <vector>
    #include <iterator>
    using namespace std;
    
    int main() {
        vector<int> nums {1, 2, 3, 4, 5};
        
        // 使用迭代器遍历向量中的元素
        vector<int>::iterator it;
        for (it = nums.begin(); it != nums.end(); ++it) {
            cout << *it << " ";
        }
        
        cout << endl;
        
        // 使用反向迭代器逆序遍历向量中的元素
        vector<int>::reverse_iterator rit;
        for (rit = nums.rbegin(); rit != nums.rend(); ++rit)
    
  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: STL (Standard Template Library) 是 C++ 的标准库,它提供了许多预定义的模板,例如容器、算法、迭代器等,使得程序员能够方便快捷地完成一些常见的任务。如果你想用 C 语言来写一个 STL,你需要自己实现 STL 中的所有功能。由于 C 语言没有模板这样的高级特性,所以实现 STL 的难度相当大。如果你真的想写,建议先了解 STL 的实现原理,并研究一些开源的 STL 实现,这样可以为你的实现提供很多启发。 ### 回答2: 用C语言编写一个完整的STL(Standard Template Library)是一个非常庞大和复杂的任务,超过了300字的篇幅。因此,在这里我将概述一下STL的核心组件和功能。 STLC++标准库的一部分,提供了许多重要的模板类和函数,用于处理常见的数据结构和算法。要用C语言实现一个类似的STL,你需要具备扎实的C语言编程基础和对数据结构和算法的深入理解。 首先,你需要实现各种容器类,例如vector、list、queue和stack等。每个容器类都有其特定的数据结构和操作,例如向量、链表、队列和堆栈。你需要定义这些数据结构,并提供插入、删除和访问元素等操作。 其次,你需要实现算法部分,例如排序、搜索和操作容器的函数。这些算法非常重要,包括快速排序、二分查找和容器的遍历和修改,都需要使用C语言实现。 此外,你还需要实现迭代器,迭代器是STL中的核心概念之一。迭代器是用于在容器中遍历元素的指针或类似的机制。你需要定义迭代器的类型,并实现其与容器的操作和交互。 最后,你需要实现其他辅助功能,例如自动内存管理、异常处理和性能优化。这些功能可以提高你的STL的可用性和效率。 总之,用C语言编写一个完整的STL一个非常复杂和耗时的任务。它需要深入的编程知识和对数据结构和算法的深入了解。希望我对你提出的问题有所解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值