首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sort::sort和transform_iterator

sort::sort和transform_iterator
EN

Stack Overflow用户
提问于 2012-06-13 18:00:48
回答 1查看 612关注 0票数 1

我想对整数值列表进行排序,但在对它们进行排序之前,我应该将它们划分为一个数字N。因此,我将有一些重复的键,我将对列表中的stable_sort使用这种复制。

我的问题是,划分所有值并将划分后的值存储在列表中,然后执行排序,还是使用transform_iterator更好?使用transform_iterator将排序算法从radix_sort改为merge_sort,因为它们有巨大的时差。

例如:

代码语言:javascript
复制
//already sorted according to another parameter
thrust::device_vector<int> myvalues...

//we want to group them..
thrust::transform(myvalues.begin(), myvalues.end(), groups.begin(), divide_by_n(N));
thrust::stable_sort_by_key(groups.begin(), groups.end(), myvalues.begin();

代码语言:javascript
复制
first = thrust::make_transform_iterator(myvalues.begin(), divide_by_n(N));
last  = thrust::make_transform_iterator(myvalues.end(),   divide_by_n(N));
thrust::stable_sort_by_key(first, last, myvalues.begin());

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-22 02:54:42

根据这篇文章(@JaredHoberock的评论),第二个不起作用。How to sort with less precision on keys with Thrust library

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11012525

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档