|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
" [9 v' }6 h6 c6 l1 e- z
两个vector 去重复,相交,合并的函数分享
/ ?" }! u3 x% f: c- l; W% u$ _. ]1 ?, A6 q2 {. U& a
[mw_shl_code=c,true]//容器vector中元素的去重
8 b7 c+ @ @" p! H$ N' H! b8 Tvector<int> unique_element_in_vector(vector<int> v){ ; E2 E* g( s+ @7 i. T$ `7 ~
vector<int>::iterator vector_iterator;
& i# q3 g( o+ g sort(v.begin(),v.end());
k8 ~. m1 C# k5 { vector_iterator = unique(v.begin(),v.end()); 3 n, n9 J- O! _5 {6 N J
if(vector_iterator != v.end()){ ) V% |, m, X) F4 e) y; W$ g
v.erase(vector_iterator,v.end()); 9 C. X# k9 B9 @3 r1 {# Z6 u5 R, ~
}
, f+ J0 ^9 v H! u5 Y' } return v;
6 o* `7 Y, K# }/ x}
+ e( y& L$ ?; W/ z& ?$ G
2 Y1 L3 `7 z o# g9 m6 f//两个vector求交集 S" X6 G$ h9 Q6 M1 A q
vector<int> vectors_intersection(vector<int> v1,vector<int> v2){ ! Z: _& _/ G" g+ d1 n# y+ E5 m
vector<int> v;
: p: ]3 Q0 W0 X* E- S3 ]/ R% b sort(v1.begin(),v1.end());
$ M7 X# w) W% H0 W5 g8 W& @ sort(v2.begin(),v2.end());
' V$ S# s8 g: Z. C2 b" M$ s% E0 W set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 ' T" }% f/ S! C* b
return v; 0 a# a9 J1 S! y x3 {; D' K6 s _
} ) l2 h) s0 K; }; o1 w4 k
7 X3 H R) i' z }; G//两个vector求并集 / ^ p r. t* l- P+ S, z' z
vector<int> vectors_set_union(vector<int> v1,vector<int> v2){
5 Y8 M$ K/ r1 J vector<int> v; ) p% X/ D% e" N" V
sort(v1.begin(),v1.end());
{; K4 Z# \: u; E& o2 [ sort(v2.begin(),v2.end()); 7 h3 ], @2 {& M, o
set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集
2 v2 f" y* |8 h, D0 h% }% Z: M return v;
; \5 V5 ^1 [# l4 z9 |' g: U- o} & G! y( o( _% I
1 c# e" [1 _* }5 R1 ^! V
//判断vector的某一元素是否存在
( X2 V; h! g. H# W4 U' nbool is_element_in_vector(vector<int> v,int element){
# I( `3 N9 q: W# g g# l vector<int>::iterator it; 1 ^1 R1 U g% I0 `$ h7 Z
it=find(v.begin(),v.end(),element);
- N! \+ {! S* A0 x if (it!=v.end()){
2 ]" v& R0 L F2 R return true;
/ n8 r+ W4 {9 v: K" ?3 d. n } ' L$ d- ` U* A* T6 e+ Y6 Y
else{
9 B3 a4 b) Z% N3 ]; s% A return false;
7 X) U+ o) L* S9 \5 s- Q/ U } 4 z* [" e& R7 |: N) a, S
} c9 Q8 }/ A0 N
[/mw_shl_code]. J5 c: w8 W; i% T
|
|