|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
) i" v. A+ z4 r1 B+ j7 K' _
& o) _. r. A+ ?$ z; _* X
C++虽然对vector封装了大量的函数,比如判断元素是否在vector中find、去重的unique,还有在algorithm类中对两个vector求交集、并集的函数,但是,这些函数是不可以直接vector.XX来使用的,如同在《【C++】容器类》中提到过如何删除vector的其中元素一样,需要搭上迭代器iterator对其进行遍历才能完成这个动作。这是不同于java与c#的,习惯就好。具体如下代码所示:# X5 `2 b8 m3 ~) }- c+ B
[mw_shl_code=cpp,true]#include "iostream"
( T& W2 Y% _9 e+ ~1 }/ Y; r#include "vector" , g9 J+ z0 r- j3 f M0 {9 E
#include "algorithm" //sort函数、交并补函数 s$ \* K0 T, x2 g# y! W7 H8 {
#include "iterator" //求交并补使用到的迭代器
7 m, J/ ?6 P! zusing namespace std;7 D9 @' ?' |/ W4 M
( E2 d, j4 V; n# V5 i9 Y//打印容器vector
9 L5 t7 G8 M, Evoid print_vector(vector<int> v){
6 t1 d% I0 R7 L" ~2 Z) j+ J0 C if(v.size()>0){
0 h) H! b1 E4 Y2 M: G1 r cout<<"{";
' n# }/ y E) _6 a7 u8 c for(int i=0;i<int(v.size());i++){ 0 F# E! n, @0 ~" k
cout<<v<<","; 4 x" V( F w/ `
}
* ? J4 t4 G% e% F6 e: a- Q" } cout<<"\b}";
6 u) C7 O4 J: X0 o3 w/ K }
" E- b- K4 w+ N. [ else{8 r' E# Z! U0 q
cout<<"{}";8 m# E* L9 i! g' _9 ?8 u
}( h% y% l8 Z& u/ [
}+ ^* @( N9 H7 b3 G& h" J3 B, B9 a! B" p
! [; P2 m! p# ?" a( k//容器vector中元素的去重
8 v- v" `6 E" k6 Q: u: |vector<int> unique_element_in_vector(vector<int> v){; a, O& f% V; L0 S
vector<int>::iterator vector_iterator;1 Q9 }. A: A/ i; g" q+ R8 Z5 W
sort(v.begin(),v.end());
* q i: V7 F# h) l# P vector_iterator = unique(v.begin(),v.end());
: ^) {/ H) D6 T) l if(vector_iterator != v.end()){
& e/ S* I' N" C# P v.erase(vector_iterator,v.end());
9 |. c8 t* [+ X9 G$ E, C }% z. y' x0 @! {& G8 z, j# J
return v;
" M! @: w' C A( S" I- d}) f' g/ N T8 _4 z
- t4 H+ Z' [3 X, b6 H$ r) {//两个vector求交集
9 |; j6 Z" B; X0 i6 d, o. tvector<int> vectors_intersection(vector<int> v1,vector<int> v2){
$ e5 O3 L+ V1 F! |% l4 e vector<int> v;. M& o6 h# e& x
sort(v1.begin(),v1.end());
: ^; k' S$ ~" y4 J- E* R, t sort(v2.begin(),v2.end()); ) Q$ v0 z* c- E% S, c8 h; X
set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集
! S0 i q/ L: s- v return v;" j0 f: w: k& X5 w) [/ j. t
}6 d2 T% u. ^% j3 L+ M' C/ I0 u0 v0 }% w
9 X0 ^ K5 c& I+ A; j4 l
//两个vector求并集, z+ O0 z7 ?( F: E4 ?7 U
vector<int> vectors_set_union(vector<int> v1,vector<int> v2){
5 T# {5 F+ H C2 _ vector<int> v;
" ~0 ]# \4 t8 [+ Z sort(v1.begin(),v1.end()); 2 }) V) F: y0 ~$ o5 V
sort(v2.begin(),v2.end()); + x) k: G, m% Z
set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集
* S4 d) o* J) o* u( `3 Y( K8 B return v;8 N. D9 Z+ c9 {0 T0 l9 z$ ]: I& Y, a5 f
}: l% V: }& I$ k2 t6 E) Q! y
9 x1 H6 B6 u4 b" [% b1 x
//判断vector的某一元素是否存在
* u+ z. R0 }2 |" {1 Wbool is_element_in_vector(vector<int> v,int element){ c7 H7 h( }" i& |0 e2 Z6 a" X
vector<int>::iterator it;* g0 d; A6 r# J( ^2 a
it=find(v.begin(),v.end(),element);( M9 ~* v# k9 {; L
if (it!=v.end()){0 v4 b2 t2 P- k' U* t. Y
return true;
) L$ G2 }2 w$ u }
+ v; e) ^+ }' o6 ^5 G else{8 H. P0 z" j v; V) }
return false;! M. p* _2 _# z$ d( p
}
; P8 B0 P% V/ o: Z D}
6 f( u# M3 i! u, G! n6 S
. s! J/ d6 d9 t! ?* Q* a; Mint main(){1 h: \4 B# k* W) q
vector<int> v1,v2,v;
- C+ ?2 e+ Q5 D5 x( I v1.push_back(22);v1.push_back(22);v1.push_back(23);v2.push_back(23);v2.push_back(24);# D: j; n2 W) A, G$ \8 N5 v
cout<<"v1是否存在1这个元素?"<<is_element_in_vector(v1,1)<<endl;
2 t% d! e }) E3 F1 w9 B# B cout<<"对v1去重:";: a- U% Y" m d( ^% B% ]
v1=unique_element_in_vector(v1);
! t: v) b* C& S. w% }& R% t% a print_vector(v1);9 w; E A9 b) `$ T {# w$ e% k: a
cout<<endl;
% m) `' H8 M) t; d cout<<"求v1与v2的交集:";
0 _% [1 z T6 o3 T) ]# a- _ v=vectors_intersection(v1,v2);
; O% ?, k ?8 d2 C print_vector(v);
0 J: ?# ?) ?) C* f4 X cout<<endl;2 b' O2 b0 V6 F7 P
cout<<"求v1与v2的并集:";
. V* g* G, N c6 H3 L$ ~ b4 u- ~ v=vectors_set_union(v1,v2);( j- ]4 s2 `& b# H" [4 s
print_vector(v);
. j/ m/ s- M4 ?8 `( ]7 _ return 0;
- T! Z' `" V4 o" K}[/mw_shl_code]
2 m. J4 X4 ]- A, P |
|