|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
4 z. T+ l _3 I& ?两个vector 去重复,相交,合并的函数分享
3 @. D% m) ?- Y/ I& b( A, i" D r" F0 f/ Y5 g
[mw_shl_code=c,true]//容器vector中元素的去重 0 x6 l9 W3 @+ G4 ^
vector<int> unique_element_in_vector(vector<int> v){
+ L& N0 l% q& J: s: o, Y vector<int>::iterator vector_iterator; ; _2 Z* D3 H o$ Q/ f% p
sort(v.begin(),v.end());
: A+ x" c# H8 I$ J. T6 B' s vector_iterator = unique(v.begin(),v.end());
1 N9 I' q& [! h' g1 M if(vector_iterator != v.end()){ 0 e4 i( ~' u; w3 N; n, ?9 t3 f6 A& R# @
v.erase(vector_iterator,v.end());
7 H" I( M& x+ J* L& O7 Q) l' H6 x } 2 c- Y; @3 L7 C, r' b* D
return v; 0 e. K6 i( @! E2 y, p0 Z+ e7 N9 M7 v
}
: P4 h. J7 i* L, y- V8 B/ W9 F a0 a Q; h Q) U6 x: }
//两个vector求交集
( ~, U# K) v2 zvector<int> vectors_intersection(vector<int> v1,vector<int> v2){
) r/ o, z* T) B6 s& c$ b vector<int> v;
' V6 B4 c4 `- P+ O sort(v1.begin(),v1.end()); P! n0 i; B# @- B% _
sort(v2.begin(),v2.end()); / \2 _9 T- F2 k8 B7 ]) Z/ M7 n0 q
set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 : ]7 t" m$ i& a& F- d" P7 u6 T/ t
return v; * r. d; A G; t. ^' Y9 q$ Q, E
}
+ q9 V. V* V9 S" v; X: |1 S 1 {) F6 E5 t! o9 O' Y# O
//两个vector求并集 : b$ p6 U1 M. d% {. W
vector<int> vectors_set_union(vector<int> v1,vector<int> v2){
+ X' J, _- p9 ?" Z' Z2 v" i5 i vector<int> v; " [1 R8 ]9 G- n
sort(v1.begin(),v1.end()); + R( h- N9 x. A# A
sort(v2.begin(),v2.end());
0 e7 X& v% G' M) m, D1 F+ h set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 + y4 n3 W- d7 {2 x5 p& V
return v;
2 `; K r# n- q4 ?6 {. r) [}
& B3 o& H `, f
/ @4 R( u' O7 C9 B- r( |//判断vector的某一元素是否存在 : P$ p8 n6 J/ L
bool is_element_in_vector(vector<int> v,int element){
& P1 f5 S2 {* @ vector<int>::iterator it;
4 a. _# s8 S) L1 ~* w+ W: I it=find(v.begin(),v.end(),element); % j2 a0 x3 o% b4 _) x3 M
if (it!=v.end()){
* L& k6 h5 v. o; c; r! S$ R* w: u return true;
- ~' ]( n2 h% ^; k+ J: x } ; c, C$ Q+ P" b6 M& A1 v' m: u
else{
! `! u8 [ Y8 I return false; + v) i! X! b+ Z7 M
} 2 j. f! }2 |! r R" ]" j- Q1 B9 ~
}
3 Z8 U: {+ P1 W. ^ [/mw_shl_code]9 r/ u. ]! M, y
|
|