std::vector .back
时间: 2023-12-14 07:03:48 浏览: 80
std::vector.back() 是一个函数,它返回 vector 容器中最后一个元素的引用。如果 vector 容器为空,则该函数的行为是未定义的。
例如,以下代码演示了如何使用 std::vector.back() 函数:
```
#include <iostream>
#include <vector>
int main() {
std::vector<int> vec = {1, 2, 3, 4, 5};
std::cout << vec.back() << std::endl; // 输出 5
vec.back() = 6;
std::cout << vec.back() << std::endl; // 输出 6
return 0;
}
```
在上面的代码中,我们首先创建了一个包含整数 1 到 5 的 vector 容器。然后,我们使用 vec.back() 函数输出了容器中的最后一个元素,即 5。接下来,我们将最后一个元素的值更改为 6,并再次使用 vec.back() 函数输出了容器中的最后一个元素,即 6。
相关问题
template <typename T, typename U> static void convert(const std::vector<std::vector<T>>& inputs, std::vector<std::vector<U>>* outputs) { outputs->reserve(inputs.size()); std::transform(inputs.begin(), inputs.end(),outputs->back, [](const std::vector<T>& p, std::vector<U>* q) { return convert(p, q); }); }
这是一个 C++ 的函数模板,用于将一个二维的元素类型为 T 的向量 inputs 转换为元素类型为 U 的向量 outputs。函数中使用了 lambda 表达式和 STL 算法 transform()。
具体来说,函数首先通过 reserve() 函数为输出向量 outputs 分配足够的内存,以避免多次动态地分配空间。然后,使用 STL 算法 transform() 对输入向量 inputs 进行转换,并将结果存储在输出向量 outputs 中。在 transform() 函数中,使用了一个 lambda 表达式,该表达式将每个输入向量 p 转换为一个输出向量 q,并返回结果。其中,convert() 是另一个函数模板,用于将元素类型为 T 的向量转换为元素类型为 U 的向量。
需要注意的是,调用该函数时,需要传递一个指向输出向量的指针,该指针指向的向量需要在调用之前已经被创建并分配足够的空间。
#include <iostream> #include <map> #include <vector> #include <algorithm> void brotherWord(std::vector<std::string> strVect, std::string word, int k) { std::multimap<std::string, int> rtnMap; //存放是兄弟单词的容器 std::vector<std::string>::iterator iter = strVect.begin(); while(iter != strVect.end()) { std::string curWord = *iter; if(curWord != word) //兄弟单词不能一模一样 { std::string tempword = word; std::sort(tempword.begin(), tempword.end()); std::string tempcurword = curWord; std::sort(tempcurword.begin(), tempcurword.end()); if(tempcurword == tempword) //是兄弟单词 { rtnMap.insert(std::pair<std::string, int>(curWord, 1)); } } iter++; } // print(rtnMap); std::vector<std::string> rtnVect; std::multimap<std::string, int>::iterator iterMap = rtnMap.begin(); while(iterMap != rtnMap.end()) { rtnVect.push_back(iterMap->first); iterMap++; } std::cout << rtnVect.size() << std::endl; if(rtnVect.size() > 1) std::cout << rtnVect[k-1] << std::endl; } int main() { int n; std::cin >> n; std::vector<std::string> strVect; while(n--) { std::string temp; std::cin >> temp; strVect.push_back(temp); } std::string word; std::cin >> word; int k; std::cin >> k; brotherWord(strVect, word, k); return 0; }注释
这段代码是一个查找兄弟单词的程序。它首先从输入中读取一个整数n,表示要输入的单词数量。然后依次读取n个单词,存储在一个名为strVect的字符串向量中。接下来,程序读取一个单词word和一个整数k。函数brotherWord将在strVect中查找与word是兄弟单词的单词,并将它们存储在一个名为rtnVect的字符串向量中。如果rtnVect中的单词数量大于1,则输出第k个单词。
整体来说,这段代码实现了一个简单的兄弟单词查找功能。
阅读全文