PLM之家PLMHome-工业软件与AI结合践行者

[资料] 元素是否在vector中,对vector去重,两个vector求交集、并集

[复制链接]

2018-7-2 19:41:23 2398 0

admin 发表于 2018-7-2 19:41:23 |阅读模式

admin 楼主

2018-7-2 19:41:23

请使用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
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了