- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在第2版的programming pearls的140页上,jon提出了一种位向量集的实现。
现在我们将讨论最后两个利用集合表示整数这一事实的结构。位向量是第1列的老朋友。以下是它们的私有数据和功能:
enum { BITSPERWORD = 32, SHIFT = 5, MASK = 0x1F };
int n, hi, *x;
void set(int i) { x[i>>SHIFT] |= (1<<(i & MASK)); }
void clr(int i) { x[i>>SHIFT] &= ~(1<<(i & MASK)); }
int test(int i) { return x[i>>SHIFT] &= (1<<(i & MASK)); }
i & MASK
是为了得到较低的5位i,而
i>>SHIFT
是为了向右移动5位i。
最佳答案
了解情况的关键是要认识到BITSPERWORD
=2SHIFT
。因此,x[i>>SHIFT]
查找数组中哪个32位元素的位对应于x
。(通过向右移动i
5位,您只需除以32即可。)一旦找到i
的正确元素,x
的较低5位便可用于查找i
的哪个特定位对应于x[i>>SHIFT]
。这就是i
所做的;通过将1移这个位数,您将对应于1的位移到i & MASK
内对应于x[i>>SHIFT]
中第i
位的精确位置。
这里有更多的解释:
假设我们需要位向量中x
位的容量。由于每个N
包含32位,我们需要存储int
(N + 31) / 32
值(即n/32向上取整)。在每个int
值中,我们将采用从最低有效位到最高有效位的顺序的约定。我们还将采用这样的约定:向量的前32位在int
中,后32位在x[0]
中,以此类推。下面是我们正在使用的内存布局(显示与每个内存位对应的位向量中的位索引):
+----+----+-------+----+----+----+
x[0]: | 31 | 30 | . . . | 02 | 01 | 00 |
+----+----+-------+----+----+----+
x[1]: | 63 | 62 | . . . | 34 | 33 | 32 |
+----+----+-------+----+----+----+
etc.
x = new int[(N + BITSPERWORD - 1) >> SHIFT]
x[1]
(要么设置它,要么清除它,要么只知道它的当前值)。我们需要首先确定要使用
i
的哪个元素。由于每个
x
值有32位,这很容易:
subscript for x = i / 32
int
元素是:
x[i >> SHIFT]
x
的特定位。查看内存布局,不难发现窗口中的第一个(最右边的)位对应于位索引
i
。(窗口在
32 * (i >> SHIFT)
中的
i >> SHIFT
插槽之后开始,每个插槽有32位。)因为这是窗口中的第一位(位置0),所以我们感兴趣的位在位置
i - (32 * (i >> SHIFT))
x
(实际上,这是mod运算符的一个定义),而mod运算符又总是等于
i % 32
。因为最后一个表达式是计算我们想要什么的最快方法,所以我们将使用它。
i & MASK
)的一个位开始,向左移动
1
位,将其移动到窗口中与位向量中的位
i & MASK
相对应的位置。这就是表达
1 << (i & MASK)
i
中那个位置的值,我们知道我们实际上是在设置、清除或查询位向量中的位
x[i>>SHIFT]
的值。
关于algorithm - 《 Programming Pearls,第二版》中set的位矢量实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11400242/
我正在尝试将字符串列表转换为字符向量的向量: import collection.breakOut def stringsToCharVectors(xs: List[String]) = x
我正在尝试使用 Pytorch 通过 2D 向量(嘈杂语音帧序列)的回归来预测 1D 向量(干净语音数据帧) data) - 之前已经完成过。帧序列为帧提供时间上下文,以更准确地预测干净帧。这些向量可
在尝试构建时,我收到此错误: Operator '+=' is ambiguous on operands of type 'Vector3' and 'Vector2' 这是问题出处的脚本代码: u
是否存在实现 FIFO 意义上的循环数组或向量的 R 包? 假设我们有这个数组: 2 4 7 1 当在位置 1 插入一个新的观察值(比如 3)时,我希望第 n 个元素被第 n-1 个元素替换: 3 2
我在游戏中有两个对象,为此可以将其视为 2d 平面上的点,但我使用 Vector3s,因为游戏本身是 3d。 我有一个游戏相机,我想将其与两个物体垂直(也在平面上)对齐,以便它们都在相机的视野中。由于
我做了一个Telegram robot ,它的工作之一是从音频文件创建样本。现在对于发送给它的大多数音频,样本都非常好;像这样: 但是,对于一些音频,样本看起来有点奇怪: 如您所见,此文件中的波形未显
由于对 JavaScript 非常陌生,我在使用 JQuery VectorMaps 时遇到了以下问题: 当我用这种语法突出显示一个国家时,一切都很完美: jQuery('#vmap').vector
我正在使用 ChartJS 在我的网站中包含一些 map ,但 ChartJS 库没有我想要的 map 。 我想知道这种类型的矢量 map 是否很容易在网上免费找到,还是必须从头开始构建? Chart
我需要创建一个函数。在此范围内,我需要发生以下事情: List 1: '(a 5 6) List 2: '(c 8 10) List 3: '(d 4 9) 以上是列表。我需要忽略每个列表的第一列(这
我在地球表面有一个点,我正在将其从地球中心转换为向量。 我有一个以度数表示的真北航向,描述了该点将在地球表面行进的路径。 我需要计算一个向量,该向量垂直于该点沿地球表面的路径所创建的平面。 我尝试
大家好,这是我的 JavaScript 代码,用于为矢量 map 制作 ip 标记以显示在线 ip.. 所有 ips 都有 3 个不同的端口,例如:ip1:1020 或 ip2:5050 或 ip3:
我正在使用 Three.js 透视相机,我需要了解相机所注视的点。 如何使用相机的矩阵/旋转向量计算它? 最佳答案 相机向下看它的内部负 z 轴。所以选择相机负 z 轴上的任意点,如下所示: var
重要提示:请注意这个问题是关于 VECTOR map 的。不是高度图。 我正在尝试在 Scenekit 中实现 Vector 位移,如 apple 演示文稿中所述: https://www.youtu
我正在处理一个稳定增长的语料库。我使用用 Python 实现的 Doc2Vec 来训练我的文档向量。 是否可以更新文档向量? 我想使用文档向量进行文档推荐。 最佳答案 单个向量可以更新,但是 gens
我正在努力寻找一种比较(测量)两个不同信号之间相似性的好方法。我不想找出一个信号到另一个信号的时间延迟,但我想看看它们之间有何相似之处。例如,我有以下两个信号,比如说 s1 ans s2。这两个信号看
我想绘制 y 与 x 线,然后在它上面我想绘制向量。我可以使用 matplotlib 的 plot 和 quiver 函数来做到这一点。但是,矢量将始终绘制在线的后面,而不是在线的顶部。也就是说,线将
包含复数的向量 a 的大小为 N×1。任务是找到乘法a * a^HA (N-by-N) >,其中 H 是 Hermitian 算子(共轭转置),因此矩阵 A 是 Hermitian。 有没有比 O(N
三天来,我一直在努力从我的响应中获取复杂类型(列表),但总是收到 ClassCastException D/SOAPEnvelope(1552): Error: java.lang.ClassCast
在我的 android 项目中,我想要离线 map 。使用图 block ,我的 map 占用 500 MB 的空间,我还想在 map 上离线搜索地址。我认为减小尺寸并使搜索成为可能的唯一方法是矢量
什么是 Android Compose 方法来平铺图像以用小图案填充我的背景? 没有旋转的位图的天真方法可能是这样的: @Composable fun TileImage() { val pa
我是一名优秀的程序员,十分优秀!