vector,map 和 pair 的基操和易错点

1.pair

单个元素 pair<int, int> a;

多个元素 pair<int, int> a[N];

其中int 可以被替换成多种类型,比如double,string, 甚至vector

# define x first
# define y second
pair<int, int> a;

a.x = 1; a.y = 2;//存储(1,2)

2.vector

动态数组,格式为vector<某类型>,可以是int,double,string,甚至pair

输入和操作:

vector<pair<int, vector<int>>;
vector<int> v;
int n = 5;

for(int i = 0; i < n; i++)
{
    int t;
    scanf("%d", &t);
    v.push_back(t);
}
//注意:不能按v[i]输入,静态数组(正常数组才可以)

v[2] ++;
printf("%d", v[3]);
//后面的就都可以用v[i]来表示了
map<vector<int>, int> a;
vector<pair<int, vector<int>>> ans;

for(auto p : a)
{
	ans.push_back({-p.y, p.x});
    //vector的pair存储用法 
}

sort(ans.begin(), ans.end());
//vector 排序 

for(auto p : ans)
{
	printf("%d", -p.x);//默认从小到大排,此处为从大到小排
	for(auto a : p.y)//遍历vector
	    printf(" %d",a);
	puts("");//for(auto p : ans)的换行 
}

3.map

map中可以插入pair,但是unordered_map不行

unordered_map和unordered_set的内部实现是哈希表,这就要求作为key应该可哈希,所以pair和vector一类都不行

map和set的内部实现是树(红黑树,更高级的二叉搜索树),pair和vector为二叉搜索树的搜索提供方法,所以pair<int, int >和vector<int> 可直接作为key使用

哈希表的value可以是其他数组类型,比如vector

map<pair<int, vector<int>>, int>;

map.size();//测量map的大小
unordered_map<vector<int>, int> map1; // 这种用法错误
map<vector<int>, int> map2;  // 用法正确
unordered_map<int, vector<int>> map; // 用法正确

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值