|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
6 e. R! Y* D4 p& T
两个vector 去重复,相交,合并的函数分享+ B! A! y8 q! F1 c& L8 \- ~$ e
* u1 A2 u7 u/ v, |
[mw_shl_code=c,true]//容器vector中元素的去重 4 p/ k: e1 B! x2 ]5 S: t) ?% b
vector<int> unique_element_in_vector(vector<int> v){ ; A y+ w2 W& v& N" o
vector<int>::iterator vector_iterator; 7 L$ R, b% K' v: B8 k$ E" V
sort(v.begin(),v.end()); 3 K0 O, j; N! R% d" b6 M
vector_iterator = unique(v.begin(),v.end());
' G) n9 o/ o3 ~$ Y if(vector_iterator != v.end()){
* R# ^2 @: X1 M+ c( }+ D v.erase(vector_iterator,v.end()); ! w ]4 e7 r$ x6 o' E# ], f
}
8 G2 R$ U5 _+ ~" i% g return v;
0 y* s2 C/ ]& o- M: N# [} ) f' s$ R8 y, N9 R9 i8 X" T: v
: a- v+ E& _( e1 c# ?! Y4 r//两个vector求交集 " S' ^, i7 ~' Q
vector<int> vectors_intersection(vector<int> v1,vector<int> v2){
9 r$ Q, G" H# M& o, o- ~* x vector<int> v; 5 A! Q7 s! |3 ?# z: {# { T
sort(v1.begin(),v1.end()); # @) @, r+ o9 x8 P7 | b
sort(v2.begin(),v2.end()); 5 ~/ h' f( J" |5 d0 x
set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 - ^* r9 P6 ^ J
return v; 4 K/ c( |# J5 q7 |1 ?- g
} " A& _$ i1 @: e5 f% V: h2 q8 N5 Q+ O
# J& t3 w; M7 r0 ?( h% [% r9 h//两个vector求并集 . l/ |' i+ x2 m4 K/ V$ r
vector<int> vectors_set_union(vector<int> v1,vector<int> v2){ 5 ^9 E" Q) d# f, T8 }
vector<int> v; * n0 R/ M$ H; k. ]- c
sort(v1.begin(),v1.end());
/ N! i4 r9 V7 c. @ sort(v2.begin(),v2.end()); ) O6 G+ }: {+ r8 F
set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 1 Z# t$ a6 w9 g7 M! }
return v; 2 M3 p0 p: {8 h% j. m
} & m% ]7 |4 ?: t" o/ ^+ p2 y
% H, p% Z- B1 j6 V# S5 U//判断vector的某一元素是否存在
& {( v! N) J9 q( x) x" Jbool is_element_in_vector(vector<int> v,int element){ + g @0 q, n! u$ \
vector<int>::iterator it;
4 w! |) k, @) I2 l6 m0 e it=find(v.begin(),v.end(),element); 4 R f8 S% q2 o
if (it!=v.end()){
2 p7 S# Z: x6 @% ]0 @8 q% l return true; 0 x+ R6 O4 E5 A( A
}
7 _, f' m" o' g5 m else{ ; v o6 Z4 l- ?) q
return false;
4 R/ e1 a' Q B; H! l, o, R' p* M } 2 z0 K) H- I. [
} 8 I/ b, A1 K5 Z- i
[/mw_shl_code]
. a3 o/ p9 Q, ]/ L! V |
|