C++编程:set、map和stack基本操作解析
版权申诉
49 浏览量
更新于2024-08-26
收藏 253KB PDF 举报
"C++编程语言中的集合数据结构主要包括set、map和stack,这些容器在不同的场景下有着各自的用途。下面是对这三个数据结构的详细介绍。
1. set(集合)
C++中的set是一种关联容器,它存储唯一对象的集合。这意味着集合内的元素不允许重复。set通常基于红黑树实现,保证了插入、查找和删除操作的时间复杂度为O(log n)。要使用set,首先需要包含`<set>`头文件。声明set变量的语法如下:
```cpp
std::set<std::string> mySet;
```
添加元素到set中,可以使用`insert()`函数:
```cpp
mySet.insert("Element1");
```
遍历set通常使用迭代器(iterator)进行,如下所示:
```cpp
for (std::set<std::string>::iterator it = mySet.begin(); it != mySet.end(); ++it) {
std::cout << *it << std::endl;
}
```
另外,也可以将数组转换为set,如下:
```cpp
int arr[] = {1, 2, 3, 4, 5};
std::set<int> mySet(arr, arr + sizeof(arr) / sizeof(int));
```
2. map(字典)
map是另一种关联容器,它存储键值对(key-value pairs)。每个键都是唯一的,并且与一个特定的值相关联。map的声明方式如下:
```cpp
std::map<std::string, int> myMap;
```
插入键值对的语句如下:
```cpp
myMap["Key1"] = 100;
```
删除元素使用`erase()`函数,传入键作为参数:
```cpp
myMap.erase("Key1");
```
遍历map时,`begin()`和`end()`返回的迭代器会依次指向键值对,其中`first`表示键,`second`表示值:
```cpp
for (std::map<std::string, int>::iterator it = myMap.begin(); it != myMap.end(); ++it) {
std::cout << "Key: " << it->first << ", Value: " << it->second << std::endl;
}
```
3. stack(栈)
stack是顺序容器,遵循后进先出(LIFO)原则。声明stack如下:
```cpp
std::stack<int> myStack;
```
入栈操作使用`push()`,出栈使用`pop()`,查看栈顶元素但不删除使用`top()`:
```cpp
myStack.push(1);
myStack.push(2);
std::cout << "Top element: " << myStack.top() << std::endl;
myStack.pop();
```
如果要输出stack中所有元素,由于stack没有内置的遍历机制,可以通过辅助变量或临时stack实现:
```cpp
while (!myStack.empty()) {
std::cout << myStack.top() << std::endl;
myStack.pop();
}
```
了解并熟练掌握set、map和stack的用法对于编写高效且优雅的C++代码至关重要。它们提供了方便的数据组织方式,使得在处理数据时能更快速地进行查找、插入和删除操作。"
2020-06-15 上传
2018-05-10 上传
2012-04-06 上传
2008-01-12 上传
2023-06-25 上传
2023-02-27 上传
2018-06-28 上传
2024-02-06 上传
2019-08-26 上传
一诺网络技术
- 粉丝: 0
- 资源: 2万+