码迷,mamicode.com
首页 > 其他好文 > 详细

数据的离散化

时间:2017-04-20 10:17:22      阅读:133      评论:0      收藏:0      [点我收藏+]

标签:color   name   算法   names   strong   ret   重复元素   clu   sort   

使用STL算法离散化:
思路:先排序,再删除重复元素,然后就是索引元素离散化后对应的值。
假定待离散化的序列为a[n],b[n]是序列a[n]的一个副本,则对应以上三步为:

#include<cstdio>
#include<algorithm>
using namespace std;
int a[1005];
int main(){
    int size,x=1,n;//离散后数组大小 
    scanf("%d",&n);
    for(int i=0;i<n;i++)scanf("%d",a+i);
    sort(a,a+n);size=unique(a,a+n)-a;//排序+去重 
    scanf("%d",&x);
    int find=lower_bound(a,a+n,x)-a;//用的时候加个lower_bound就行了 
    printf("%d",find);
    return 0;
} 

unique()函数是一个去重函数,STL中unique的函数 unique的功能是去除相邻的重复元素(只保留一个),unique(num,mun+n)返回的是num去重后的尾地址,之所以说比不真正把重复的元素删除,其实是,该函数把重复的元素一到后面去了,然后依然保存到了原数组中,然后返回去重后最后一个元素的地址,因为unique去除的是相邻的重复元素,所以一般用之前都会要排一下序。

数据的离散化

标签:color   name   算法   names   strong   ret   重复元素   clu   sort   

原文地址:http://www.cnblogs.com/bennettz/p/6737051.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!