std常用类型
std::getline
文档
std::reverse
文档
注意事项
reverse()
返回值为void
,是对原序列进行修改
std::vector
文档
emplace 和 emplace_back
两者的区别仅为前者可以指定插入元素的位置,后者是直接插入到容器末尾
当调用push_back
或insert
成员函数时,是把元素类型的对象传递给它们,这些对象被拷贝到容器中(即需要调用一次拷贝构造函数)
但调用一个emplace系列函数时,则是将相应参数传递给元素类型的构造函数,直接构造出对象并插入到容器中,不需要调用拷贝构造函数
演示程序如下
#include <iostream>
#include <vector>
using namespace std;
class A {
public:
int x;
A() {
x = 0;
cout << "默认构造执行" << endl;
}
A(int x) {
this->x = x;
cout << "带参构造执行" << endl;
}
A(const A &a) {
this->x = a.x;
cout << "拷贝构造执行" << endl;
}
};
int main() {
vector<A> vec;
A a = A(1);
vec.push_back(a);
for (A &i : vec) cout << i.x << ' ';
return 0;
}
执行结果:
#include <iostream>
#include <vector>
using namespace std;
class A {
public:
int x;
A() {
x = 0;
cout << "默认构造执行" << endl;
}
A(int x) {
this->x = x;
cout << "带参构造执行" << endl;
}
A(const A &a) {
this->x = a.x;
cout << "拷贝构造执行" << endl;
}
};
int main() {
vector<A> vec;
vec.emplace_back(2);
for (A &i : vec) cout << i.x << ' ';
return 0;
}
执行结果
emplace系列函数的核心在于调用插入元素的构造函数,因此传入的值要符合构造函数的要求
std::next_permutation
文档
注意事项
- 是按照字典序递增的顺序进行排列的,需要关注初始序列
std::function
文档
用法
类似C
语言中的函数指针
目前使用过的用法
vector
中存放lambda
表达式指明元素类型
auto op1 = [](int a, int b) -> int {return a + b;};
auto op2 = [](int a, int b) -> int {return a - b;};
auto op3 = [](int a, int b) -> int {return a ^ b;};
vector<function<int(int, int)>> ops = {op1, op2, op3};
一道例题,不使用lambda
和vector
相结合,就需要写三段重复度很高的代码
std::nth_element
官方文档
第二个参数的nth是指下标,例如带入0表示寻找下标为0,第1小的数值
示例程序
#include <iostream>
#include <algorithm>
using namespace std;
int k; // 第k+1小的元素,下标为k
int a[5] = {6, 1, 5, 2, 7};
int main()
{
cin >> k;
for (int i = 0; i < 5; ++ i) cout << a[i] << ' '; cout << endl;
nth_element(a, a + k, a + 5);
for (int i = 0; i < 5; ++ i) cout << a[i] << ' '; cout << endl;
printf("第%d小的数为%d,下标为%d\n", k + 1, a[k], k);
return 0;
}
输出结果