初始化
a.push_back(n);
翻转:reverse(a.begin(),a.end())
#include<bits/stdc++.h>
using namespace std;
int main()
{
vector<int> q[10];
for(int i=0;i<10;i++)
{
q[i].resize(10);
}
q[0][0]=5;
cout<<q[0][0];
return 0;
}
vector q[10]与vector q(10)的区别
前者是定义了10个vector变量,后者是定义了一个长度为10的vector变量。
上面的代码若写成如下形式则会出现运行错误:
#include<bits/stdc++.h>
using namespace std;
int main()
{
vector<int> q[10];
q[0][0]=5;
cout<<q[0][0];
return 0;
}
必须先利用resize申请每个vector的内存
使用min_element和max_element寻找向量中的最大值和最小值
min_element(首地址,尾地址),该函数求出的是最小值的地址,加上求址符号才能变为最小值。
当需要求最小值的下标时,需将结果减去数组(或向量)的首地址。
注意向量和数组首尾地址表示方法的区别
#include<cstdio>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<vector>
#include<cstring>
#include<queue>
#include<stack>
using namespace std;
void swap(int &a,int &b)
{
int temp;
temp=a;
a=b;
b=temp;
}
int main()
{
vector <int> q(5);
for(int i=0;i<5;i++)
{
cin>>q[i];
}
cout<<min_element(q.begin(),q.end())-q.begin();//对整个vector而言,注意申请的内存大小与使用内存之间的关系;
return 0;
}
bitset一般用于十进制转二进制
#include<bits/stdc++.h>
#include<bitset>
using namespace std;
int main()
{
int a=-10;
bitset<8> b(a);
string s=b.to_string();
cout<<s;
return 0;
}