- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
虽然在 Java 中对连续子数组进行排序没有问题,但我还没有找到任何关于如何仅在由另一个数据结构指定的某些(非连续)索引处对数组进行排序的信息,例如。一个 BitSet
。
具体来说,给定一个数组,例如
int[] x = {5,1,8,6,7,0,2,3,9,4};
和一个指定要排序的位置的 BitSet
BitSet pos = new BitSet(10);
pos.set(0);
pos.set(2);
pos.set(5);
pos.set(6);
pos.set(9); // i.e. pos = {1,0,1,0,0,1,1,0,0,1}
我想仅在掩码 pos
为 1
的位置对 x
进行内联排序,同时忽略其余索引,即
SortOnIndices(x,pos);
应该导致
x = {0,1,2,6,7,4,5,3,9,8}
是否有无需实现自定义排序解决方案即可有效归档的方法?这可以用 JAVA 8 流来完成吗?
编辑:更正了示例中 BitSet 的使用。
最佳答案
首先,BitSet.valueOf(long[])
无法按照您尝试使用的方式工作。 long[]
数组的每个元素代表 64 位而不是一个位。事实上,将您的 1,0,1,0,0,1,1,0,0,1
表示转换为 BitSet
是第一个挑战:
BitSet pos = BitSet.valueOf(new long[] { Integer.reverse(0b1010011001)>>>22 });
然后,我们遇到了一个问题,即 Java API 的每个可自定义排序实现都与对象一起工作,这将需要装箱并将源表示为数组或 List
。为原始类型提供的方法都固定为自然顺序。
尝试创建一个 List
位置或类似的,动态映射到源数组的,在找到由位集引起的正确数组位置时,会受到非随机访问的影响。但是 List.sort
的 default
实现通过将列表内容复制到数组中来规避这一点。这甚至适用于使操作看起来流畅但在幕后创建中间数组的所有 Stream
方法(并且还支持仅用于装箱值的自定义 Comparator
)。
所以当你想避免额外的内存分配时,任何内置的排序工具都无济于事。最简单、高效和节省内存的方法是
BitSet ordered = new BitSet();
pos.stream().forEach(ix -> ordered.set(x[ix]));
PrimitiveIterator.OfInt it = ordered.stream().iterator();
pos.stream().forEachOrdered(ix -> x[ix]=it.next());
assert !it.hasNext();
但这仅在源数组不包含负数或重复项的情况下才有效,例如在您的示例数据集中。
解除这些限制需要更多的努力和更多的内存:
IntSummaryStatistics stats = pos.stream().map(ix -> x[ix]).summaryStatistics();
int min = stats.getMin(), max = stats.getMax();
int[] counts = new int[max-min+1];
pos.stream().forEach(ix -> counts[x[ix]-min]++);
PrimitiveIterator.OfInt it
= IntStream.rangeClosed(min, max)
.flatMap(val -> IntStream.range(0, counts[val-min]).map(ix -> val))
.iterator();
pos.stream().forEachOrdered(ix -> x[ix]=it.next());
assert !it.hasNext();
这种计数排序的变体仍然是 O(n),但它的内存消耗取决于要排序的数字集中最小和最大数字之间的差值。但这是你能得到的最好的,除非你想实现你自己的快速排序或类似的。或者,如果最小值和最大值之间的差异太大,您可以求助于让 JRE 提供的算法对副本进行排序:
int[] tmp = pos.stream().map(p -> x[p]).toArray();
Arrays.sort(tmp);
PrimitiveIterator.OfInt it = Arrays.stream(tmp).iterator();
pos.stream().forEachOrdered(ix -> x[ix]=it.next());
assert !it.hasNext();
您甚至可以使用第二个变体的统计信息来使用需要较少内存的变体
PrimitiveIterator.OfInt it;
IntSummaryStatistics stats = pos.stream().map(ix -> x[ix]).summaryStatistics();
int min = stats.getMin(), max = stats.getMax();
if(max-min < stats.getCount()) {
int[] counts = new int[max-min+1];
pos.stream().forEach(ix -> counts[x[ix]-min]++);
it = IntStream.rangeClosed(min, max)
.flatMap(val -> IntStream.range(0, counts[val-min]).map(ix -> val))
.iterator();
}
else {
int[] tmp = pos.stream().map(p -> x[p]).toArray();
Arrays.sort(tmp);
it = Arrays.stream(tmp).iterator();
}
pos.stream().forEachOrdered(ix -> x[ix]=it.next());
assert !it.hasNext();
关于java - 如何仅在 Java 中将相同长度的 BitSet 设置为 true 的索引处对 int[] 进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47611285/
这个问题已经有答案了: What is the difference between a variable, object, and reference? [duplicate] (5 个回答) 已关
我正在使用以下代码来学习java套接字编程。它的作用是,client.java 程序从用户那里获取一个号码并将其发送到 sever.java。然后服务器将其乘以2并发回给客户端。在我的客户端程序中,它
我编写了一个自己开发的串行端口类,为了简单起见,我使用了阻塞/同步/非重叠。我浏览了所有 MSDN 文档,这对我来说很困难。 我在从端口打开、传输或接收字节方面没有任何问题。所有操作都是同步并且没有线
//Not finished -- disregard function evaluate() { var cdate = new Date(); var cday = cdate.getDa
我已经尝试过了,但它有效 例如: x= 523.897 y= x[0:"."] print y 我只想打印 523。如何让 Python 抓取字符串直到某个字母或数字? 最佳答案 行 y = x[0:
我想移动拐 Angular 处的方框(从左上角开始水平移动 Angular 落到右上角然后你去到右下角。 function myMove() { var elem = document.getEl
如何让侧边栏停止在第二个侧边栏部分而不是顶部? fiddle http://jsfiddle.net/EvAdP/2/ HTML I'm the header
我刚刚在大学开始我的第二门编程类(class),我们的第一个作业相当简单,旨在基本上检查我们的环境并检查我们是否知道如何通过类(class)网站提交作业。 当我运行我们提供的代码时,它卡在应该提示用户
我目前正忙于我的这个信息学元素(构建一个示例交友网站)。问题是我在把所有东西都放在正确的地方时遇到了一些麻烦。一切都很顺利,直到我的邮箱出现在错误的位置(但是,Dreamweaver 会按照我的意
我想,和你一样hover a GIF shot on Dribbble , 当光标位于元素高度顶部之后/50% 处时显示带有信息的 div。 测试示例 我做了这个,这是有效的,但有点棘手......特
我有一个下拉菜单,并且我已将 mouseenter 设置为选项。因此,如果鼠标位于触发器之外,菜单应该关闭。我正在使用 jQuery 1.8.0。这可能是 CSS 问题吗? 这是我初始化插件的代码。
我正在尝试在 Visual Basic for Applications 中编写一个 hello world 应用程序,即修改 Excel 工作表中的单元格。这是: Sub hello() D
我的应用程序使用 JSF 2.1 和 PrimeFaces。最近,由于一些线程卡住,观察到 CPU 利用率非常高。所有卡住线程的卡住线程转储都指向 javax.faces.component.UICo
在列出 aws cognito 用户时,我的 Node js 应用程序遇到问题。 仅当我有超过 60 个 Cognito 用户时才会出现此问题。 Reference of API 下面是我的代码片段。
我是 ubuntu 用户..我在 php 中有一个执行 python 文件的命令..python 文件设置为可执行文件..所以,我的 php 命令是:- shell_exec("try.py");
我正在尝试将剪贴板内容写入文件,但由于某种原因程序卡住了。 FILE *fp; fp = fopen("tmp.code","w"); fprintf(fp,getclip()); /*writes*
当用户向下滚动时,我使用此代码使侧边栏固定在某个 div 处。问题是我必须手动输入一个阈值数字,这并不总是理想的,因为该部分的位置可能会更改或在各种浏览器和系统之间不一致。我想知道是否有一种方法可以在
我有一个字符串数组,例如 first_page = {{"U","M","Y","Q","I","A","L","D","P"、"F"、"E"、"G"、"T"、"Z"、"V"、"W"、"H"、"O"、
我能否在页面上的特定 px 位置放置一个元素(例如图像),然后让文本围绕它流动? 必要时使用 JS/jquery。 我确实看到了这个Have text flow around an object th
第一次在这里提问。 我有两个简单的 Javascript 函数,1. 生成一个随机字母,2. 在每个单元格中使用单个字母填充 10x10 表格。创建表的主要函数是通过带有 onclick 的简单 HT
我是一名优秀的程序员,十分优秀!