PLM之家PLMHome-工业软件践行者

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

[复制链接]

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

2470

主题

1275

回帖

8万

积分

管理员

PLM之家站长

积分
82162
QQ
发表于 2018-4-3 07:56:54 | 显示全部楼层 |阅读模式

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

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

x

) r0 X3 f7 Y7 Y! p. _两个vector 去重复,相交,合并的函数分享* z) [9 H, G2 \

' g0 z& a/ E2 c7 k) C[mw_shl_code=c,true]//容器vector中元素的去重  
2 [, f7 Q+ ~& x* |& j! |+ z0 zvector<int> unique_element_in_vector(vector<int> v){  % t( S( t8 Z4 }( e
    vector<int>::iterator vector_iterator;  
$ ]! `3 R: z8 R5 Q    sort(v.begin(),v.end());  
5 M  e0 _/ H3 A+ [6 D% n6 m- z    vector_iterator = unique(v.begin(),v.end());  3 T/ I% J8 `' Z$ y4 A, u
    if(vector_iterator != v.end()){  
8 s* l- D1 S+ p8 `$ I; S- I6 H        v.erase(vector_iterator,v.end());  
6 q* I, t1 d3 W/ ^, i8 v! x    }  % T) Y8 D0 a8 B$ ]  |! ~
    return v;  $ D1 _1 {" G( X9 P9 b
}  
5 Q/ A, X' p6 H5 x7 z: ?  ( D7 S1 @/ Q- v" y
//两个vector求交集  
4 f" f: q- e. @( _& y  B) A. t) ^% ovector<int> vectors_intersection(vector<int> v1,vector<int> v2){  ; L9 E& c; \/ ^: H
    vector<int> v;  
% j/ B. }2 x1 P, T! ~  {2 `    sort(v1.begin(),v1.end());     
8 A% n9 f8 T* Y) n+ d" ~    sort(v2.begin(),v2.end());     
; c6 h3 Z+ J& K, [  ^    set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集   , ~: B% [* o$ j& j' i. I. u% @2 A( C
    return v;  
3 c9 Y6 Q$ \( B) G  e" D" d}  ! m* T% Z" t" L) j& \! N
  
2 k3 U$ ~, U3 R' _: ~  y8 a! d//两个vector求并集  ! I- A" J& J8 o* l
vector<int> vectors_set_union(vector<int> v1,vector<int> v2){  ! S7 O; j1 {1 x  b# N, \
    vector<int> v;  
! c2 g& V  w, x, I, Z9 }" e    sort(v1.begin(),v1.end());     
3 x5 a6 U) J, V, }    sort(v2.begin(),v2.end());     ' F  H" i2 f# C
    set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集   
8 P+ d( v  r8 A% y0 f" M    return v;  ) x5 o! ]2 ?7 }% O. R
}  # w! m: c9 l0 e" l% p. V
  8 l6 J! i  y5 {3 f1 |
//判断vector的某一元素是否存在  ! R; I! C5 G- M5 a" E+ I  @1 b% Y8 q9 q
bool is_element_in_vector(vector<int> v,int element){    M1 x, S! N( Q9 M+ ?
    vector<int>::iterator it;  
+ F2 B. z& a# P  ]4 T6 T. B    it=find(v.begin(),v.end(),element);  
' W4 G$ q4 o* V    if (it!=v.end()){  # _9 [, G: N- I  r, g
        return true;    p6 C# v3 O" z% A6 Y( W
    }  7 N. z2 K  `7 b3 N' l
    else{  * c0 U5 c; o2 O/ T+ a
        return false;  
* o. f$ o9 _* u5 T6 D+ [6 Q    }  . t, X& ?1 Y( `: c
}  
9 G; z" i0 D) A' }  [/mw_shl_code]
% b8 F! x( @5 m. E
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了