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

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

[复制链接]

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

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

admin 楼主

2018-7-2 19:41:23

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

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

x
6 j# \. S- l( V) b7 O4 `

9 _- s! u* j# k7 LC++虽然对vector封装了大量的函数,比如判断元素是否在vector中find、去重的unique,还有在algorithm类中对两个vector求交集、并集的函数,但是,这些函数是不可以直接vector.XX来使用的,如同在《【C++】容器类》中提到过如何删除vector的其中元素一样,需要搭上迭代器iterator对其进行遍历才能完成这个动作。这是不同于java与c#的,习惯就好。具体如下代码所示:
4 v" B% A/ g% ?  C0 s( c4 I! c[mw_shl_code=cpp,true]#include "iostream"
; z+ k8 e7 t; C0 c& u: A9 n#include "vector" 3 M/ r9 t' p) [6 w% ?. E
#include "algorithm" //sort函数、交并补函数
5 R+ V1 l1 X+ l9 ^1 s+ |#include "iterator" //求交并补使用到的迭代器8 M% Y) ~+ h7 Y4 G
using namespace std;
% f/ y1 C5 n- S0 i( C" l8 q6 b, T
: ?% j6 a4 l- z, n//打印容器vector) T* `4 l' d# E# N8 |5 H4 h, i& H
void print_vector(vector<int> v){' c: E  N% c6 i/ F
        if(v.size()>0){
+ g% d$ \0 p3 Z+ ]                cout<<"{";  ! U) \- p; T. O) a9 T
                for(int i=0;i<int(v.size());i++){  ; V# n9 U& [5 p0 ^6 K
                        cout<<v<<",";  
# }: `- d0 u% `+ r2 \4 ^                }  
% V, a4 R4 W/ j/ L' ^8 u( k% y) c                cout<<"\b}";  / t4 W- S4 G- M' b
        }  P! d9 R3 q2 f4 {+ D
        else{
* ~" Z! {* o; d6 L# d  R1 `* W                cout<<"{}";
/ P% Y3 P& Y0 X: y        }
- {' M( H0 j$ l8 }- }5 O}! g; w3 E' s: y- F; E. `5 u, }
# i% V9 I% `( Y4 z' P
//容器vector中元素的去重# A4 {0 N& s- B4 {; D# ]: H
vector<int> unique_element_in_vector(vector<int> v){' |3 y. J0 ?; _: Z5 R6 M9 F# O" B
        vector<int>::iterator vector_iterator;' r. _3 f! ^! V( |$ k) p
        sort(v.begin(),v.end());
) w8 _  R" G, T6 o% e        vector_iterator = unique(v.begin(),v.end());
3 ~0 `7 v* e0 C' a3 Y        if(vector_iterator != v.end()){
# q: H# K0 }% W4 Q. c                v.erase(vector_iterator,v.end());; d! F7 s* G8 f5 }$ W
        }- p- N8 M* Y% M& `- J9 C/ o7 |' M3 Q) D
        return v;
3 N8 K" _4 ?+ N3 N& e8 K}
- Y$ k4 J/ l* ~. T, q, h
9 @& T# V5 S3 Q+ p//两个vector求交集
" h. E. K0 y/ L1 b1 J  rvector<int> vectors_intersection(vector<int> v1,vector<int> v2){
+ T0 P6 o( w6 F6 K) w$ [) s/ \        vector<int> v;
; C0 e) @% r8 f0 Q  c        sort(v1.begin(),v1.end());   
9 l6 \1 P1 h4 M; n' J        sort(v2.begin(),v2.end());   
, I! ]. F( k/ |0 y' e- }4 ]; }        set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 & w& d& E; B, T- m! d; B
        return v;
3 H3 @! h' H% P: w# n: W5 k5 p8 c% }}, `- u) T3 h3 b* R+ S
0 n- k2 j) k& }- F6 a8 B  ?
//两个vector求并集( H# b# v4 v  e& i0 l- R, v- }; C3 ]
vector<int> vectors_set_union(vector<int> v1,vector<int> v2){1 A7 m1 K  c& p1 ~8 U
        vector<int> v;
; Y% j8 r( L" p1 l0 q7 W        sort(v1.begin(),v1.end());   
* Y  E$ v8 Q. l3 E  K6 O- E        sort(v2.begin(),v2.end());   
) f9 b! ]1 z+ C" M' B# G        set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),back_inserter(v));//求交集 # H' W: z4 k9 z. u6 d
        return v;
5 V# [- u, U- D# h5 j}
8 g0 H! L  N4 M2 z8 j. Z % R3 E9 N! T4 B6 i" T
//判断vector的某一元素是否存在4 b% a- ]. j$ k5 ^3 t) E3 ^
bool is_element_in_vector(vector<int> v,int element){" Q- C, o+ b; [
        vector<int>::iterator it;& N+ r% v  s2 X/ l. n
        it=find(v.begin(),v.end(),element);7 ~; \& |: K4 V3 s+ a
        if (it!=v.end()){( G$ n9 k' M- ~& o6 F# V: ^
                return true;5 k- M( V8 w& P* C1 a! u
        }* ^3 x) p( \' J4 ?1 g
        else{$ t; M7 h1 w' V! W% k6 P% S
                return false;! K/ L. b* v1 \' ^
        }+ |# i, M2 n3 f: y" ?# I$ W# T- Q) I
}
9 R0 t) K& p! f ! E! |1 Q% q* D/ [% V
int main(){" U( G0 D( a5 J7 Y+ K1 a
        vector<int> v1,v2,v;
: I0 d# r- X1 h" M- \8 C0 ]        v1.push_back(22);v1.push_back(22);v1.push_back(23);v2.push_back(23);v2.push_back(24);8 ]- h. i& p& b: W3 z3 k6 h3 B' ]
        cout<<"v1是否存在1这个元素?"<<is_element_in_vector(v1,1)<<endl;0 i! K. r0 i" K# H8 k" p8 t
        cout<<"对v1去重:";1 F4 p1 F; Z2 w' w  R
        v1=unique_element_in_vector(v1);  D& P' y; [" N/ `
        print_vector(v1);7 Y/ m3 n: t4 N" b& ~# l; `
        cout<<endl;
/ E' Q- Y' c2 |        cout<<"求v1与v2的交集:";; Q1 d4 k% R7 h( a4 u1 M& Y/ k
        v=vectors_intersection(v1,v2);
  Y2 Q+ r) f, \/ {; H        print_vector(v);8 b" \9 f, t( [: W. H! i. g# e
        cout<<endl;
; G; D! p/ @5 H$ L$ P: Z        cout<<"求v1与v2的并集:";
! _& c  ^9 c7 M8 w$ O) ]        v=vectors_set_union(v1,v2);
. U& N/ l+ x7 P+ _- z9 G% f3 @        print_vector(v);" b7 k1 u2 J' m
        return 0;. |4 ]  N. ~& s7 L
}[/mw_shl_code]
. E, T; A5 a# B6 ~* ?4 l5 b
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了