注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

zorksylar

Nothing is impossible , if distributed.

 
 
 

日志

 
 

c++_STL_Unique的使用  

2011-08-10 23:38:39|  分类: C++ STL |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
用stl中的unique可以消除重复

先贴上一个代码,然后再解释

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;


int main()
{
        int a[] = {1,2,2,2,3,3,2,2,1};
        vector <int> v(a, a+sizeof(a)/sizeof(int));
        sort(v.begin(),v.end());        
        vector<int> ::iterator it = unique(v.begin(),v.end());
        vector<int> ::iterator i;
        cout<<"first part"<<endl;
        for(i = v.begin();i <= it -1;i ++)
                cout<<*i<<endl;
        cout<<"second part"<<endl;
        for(i = it;i < v.end();i ++)
                cout<<*i<<endl;        
        cout<<"after delete it from the vector "<<endl;
        v.erase(it,v.end());
        for(i = v.begin();i != v.end();i ++)
                cout<<*i<<endl;

        return 0;
}

输出结果:
first part
1
2
3
2
1
second part
3
2
2
1
after delete it from the vector 
1
2
3


vector<int>::iterator p = unique(v.begin(),v.end());  unique函数返回的是一个vector<int>类型的指针,它将原数组分为两部分[v.begin(),p-1] 和 [p,v.end()];  (前者是删除重复元素的数组,后者是重复的数组;)

  评论这张
 
阅读(213)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018