PLM之家PLMHome-国产软件践行者

[资料分享] 两个vector 去重复,相交,合并的函数分享

[复制链接]

2018-4-3 07:56:54 3176 0

admin 发表于 2018-4-3 07:56:54 |阅读模式

admin 楼主

2018-4-3 07:56:54

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x
7 [# j  u. N5 y- J/ |
两个vector 去重复,相交,合并的函数分享
% j# t9 }4 z9 E. D, r" G" |
& V5 l$ p2 W8 C, Z% @: l[mw_shl_code=c,true]//容器vector中元素的去重  
9 |3 U6 g1 d! M/ U; w4 T. vvector<int> unique_element_in_vector(vector<int> v){  
3 U2 E+ O9 L7 z2 ?1 A5 W( s    vector<int>::iterator vector_iterator;  
$ v( \) l* d' k# Q. A% J( y5 u    sort(v.begin(),v.end());    F4 D/ A0 h# T& F
    vector_iterator = unique(v.begin(),v.end());  " d  g8 o. q! U1 s. ?
    if(vector_iterator != v.end()){  
& P& `; k8 x/ `5 f" i1 x        v.erase(vector_iterator,v.end());  9 M( k/ k& P, d3 Z" {; _& y% Z
    }  " F; H) N: K' Y, `0 y
    return v;  7 r3 V) X: m3 R2 |7 ^. `& y3 I0 r& ^
}  
* {1 [/ \0 r  \  
$ N9 Z( _9 Y  D& D, G0 Y1 V6 |% X//两个vector求交集  
% k" G  g3 \3 l, Y; h/ ~/ hvector<int> vectors_intersection(vector<int> v1,vector<int> v2){  3 A+ F- x5 M3 P9 j
    vector<int> v;  5 F2 O$ h% z5 W$ m3 p9 i5 t
    sort(v1.begin(),v1.end());     $ T  J  A0 @( x
    sort(v2.begin(),v2.end());     
: W* x( g( c: H/ S    set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集   , M( N% W% Z7 M; z" x: o+ g# U# |
    return v;  
2 ?+ n: J4 i. t, f}    t6 H( s" o$ j' s. |5 m8 C
  6 i5 S8 ]" \- |& x6 c
//两个vector求并集  
- p; j  s& M9 O5 ~vector<int> vectors_set_union(vector<int> v1,vector<int> v2){  
) v; g5 U6 D7 A8 d+ |# W) {8 s    vector<int> v;  
0 m/ \* \+ Z- e. R: P# n" [    sort(v1.begin(),v1.end());     
  p  H- W; r5 n+ o5 J9 W3 ?8 l    sort(v2.begin(),v2.end());     " W+ j% m# X0 l( |8 l7 V
    set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集   
9 _( ]: v% e4 b    return v;  
2 S9 n! _# G7 G4 x' j}  
4 C3 r, q8 @! Q9 K  l- t3 @! l  
! x  ?* K, O5 }/ K5 }# \' j//判断vector的某一元素是否存在  
- q" t- v, ^* x# M' ybool is_element_in_vector(vector<int> v,int element){  " o2 Q$ d1 w$ v( E; b
    vector<int>::iterator it;  + g) i" P- F1 [9 q# K  U
    it=find(v.begin(),v.end(),element);  . h' r0 }- b0 [; q% k* S
    if (it!=v.end()){  
1 l0 r7 U2 y* M' |2 i0 R6 g1 e9 v        return true;  & U% |) |& ^" w% M% f+ I
    }  ! w! C: e1 x0 M% A* j
    else{  ) j3 D" i' O! M; e+ j$ }7 L
        return false;  ; B2 @7 J$ C  d# I+ w
    }  
% F. E$ k5 M& h3 ^. n4 J}  
7 Q8 ^; s/ l9 _( A  [/mw_shl_code]- X8 f+ x  P( o6 h# K  f2 T
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了