- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的问题涉及二进制索引树(Fenwick 树)中更新步骤背后的完整推理。因此,当以一定的增量更新我们的数组时,在某个位置,更新是这样的:
void updateBIT(int BITree[], int n, int index, int val)
{
// index in BITree[] is 1 more than the index in arr[]
index = index + 1;
// Traverse all ancestors and add 'val'
while (index <= n)
{
// Add 'val' to current node of BI Tree
BITree[index] += val;
// Update index to that of parent in update View
index += index & (-index);
}
我的问题是 index += index & (-index);
部分。请注意,我了解 index & (-index)
位,尤其是在查询树的上下文中。
我已经使用这个索引更新规则手动尝试了几个示例,但我一直无法找到添加 index & (-index)
背后的逻辑。以便转到下一个需要更新的节点。
从我到现在为止,一个节点 i
在 BIT 中“负责”数组中的原始值,范围从 [i - i & (-i) + 1, i]
,所以这意味着任何节点都会落入这种形式的范围内。具体来说,据我了解,当想要更新位置时 k
在原始数组中,我们遵循以下步骤(概念上的,而不是实际代码中的):
0
: 更新BIT[k + 1]
(索引由 1
在位数组)。虽然仍在迭代 0
,我们更新我们的索引看着,所以我假设我们正在寻找下一个最小的负责节点 k
的区间, 因此我们需要找到下一个索引 i
其中 i - i & (-i) < k < i
.查找此索引 i
经过将当前索引增加 k & (-k)
.其余的迭代以相同的方式进行,直到我们超出限制。我已经手动尝试了很多示例,但我仍然不明白为什么要添加 i & (-i)
带我们到正确的下一个节点。我在网上找到的每一个教程,包括视频,在这个问题上都是完全狡猾的。
这里有几个关于BITs的相关问题,在仔细阅读之前请不要将它们与我的合并。据我所知,这个特定问题尚未得到解答。
最佳答案
所以,让我尝试通过一个简单的例子来解释上述场景。
让我们取 i = 12
。现在我们更新 BIT[12]
。现在根据算法更新的下一步是 i += i&(-i)
。
二进制中的 12 = 01100
是多少。最后一位设置为2
,值为2^2
= 4(如你所知
0th bit value is 2^0 = 1
1st bit value is 2^1 = 2
2nd bit value is 2^2 = 4.
以类似的方式用于其他位。
现在我们要更新的下一个索引是 12 + 4 = 16
。即 BIT[16]
。
现在这是关于系统如何工作的。让我尝试用简单的语言解释为什么这种技术有效。
假设我需要更新 index = 1
并且假设 MAX 数组值为 8。那么我将更新 1,2,4,8
的所有索引。
现在,假设我需要更新 index = 3
。所以我将更新数组索引 3,4,8
。
所以你看到了到目前为止 BIT[4]
是如何得到数组索引 1 到 4
中所有值的总和的。
现在假设您需要获取前 4 个数字的总和,您只需执行 BIT[4]
并且您将遍历索引 4,0
。简而言之,您不会遍历 1,2,3
。正如我们所看到的,这些索引是如何由于位操作而被覆盖的。
希望这对您有所帮助!
关于algorithm - Fenwick Trees 中的更新步骤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51640153/
我查看了网站上的一些问题,但还没有完全弄清楚我做错了什么。我有一些这样的代码: var mongoose = require('mongoose'), db = mongoose.connect('m
基本上,根据 this bl.ocks,我试图在开始新序列之前让所有 block 都变为 0。我认为我需要的是以下顺序: 更新为0 退出到0 更新随机数 输入新号码 我尝试通过添加以下代码块来遵循上述
我试图通过使用随机数在循环中设置 JSlider 位置来模拟“赛马”的投注结果。我的问题是,当然,我无法在线程执行时更新 GUI,因此我的 JSlider 似乎没有在竞赛,它们从头到尾都在运行。我尝试
该功能非常简单: 变量:$table是正在更新的表$fields 是表中的字段,$values 从帖子生成并放入 $values 数组中而$where是表的索引字段的id值$indxfldnm 是索引
让我们想象一个环境:有一个数据库客户端和一个数据库服务器。数据库客户端可以是 Java 程序或其他程序等;数据库服务器可以是mysql、oracle等。 需求是在数据库服务器上的一个表中插入大量记录。
在我当前的应用程序中,我正在制作一个菜单结构,它可以递归地创建自己的子菜单。然而,由于这个原因,我发现很难也允许某种重新排序方法。大多数应用程序可能只是通过“排序”列进行排序,但是在这种情况下,尽管这
Provisioning Profile 有 key , key 链依赖于它。我想知道 key 什么时候会改变。 Key will change after renew Provisioning Pr
截至目前,我在\server\publications.js 中有我的 MongoDB“选择”,例如: Meteor.publish("jobLocations", function () { r
我读到 UI 应该始终在主线程上更新。但是,当谈到实现这些更新的首选方法时,我有点困惑。 我有各种函数可以执行一些条件检查,然后使用结果来确定如何更新 UI。我的问题是整个函数应该在主线程上运行吗?应
我在代理后面,我无法构建 Docker 镜像。 我试过 FROM ubuntu , FROM centos和 FROM alpine ,但是 apt-get update/yum update/apk
我构建了一个 Java 应用程序,它向外部授权客户端公开网络服务。 Web 服务使用带有证书身份验证的 WS-security。基本上我们充当自定义证书颁发机构 - 我们在我们的服务器上维护一个 ja
因此,我有时会在上传新版本时使用 app_offline.htm 使应用程序离线。 但是,当我上传较大的 dll 时,我收到黄色错误屏幕,指出无法加载 dll。 这似乎与我对 app_offline.
我刚刚下载了 VS Apache Cordova Tools Update 5,但遇到了 Node 和 NPM 的问题。我使用默认的空白 cordova 项目进行测试。 版本 如果我在 VS 项目中对
所以我有一个使用传单库实例化的 map 对象。 map 实例在单独的模板中创建并以这种方式路由:- var app = angular.module('myApp', ['ui', 'ngResour
我使用较早的 Java 6 u 3 获得的帧速率是新版本的两倍。很奇怪。谁能解释一下? 在 Core 2 Duo 1.83ghz 上,集成视频(仅使用一个内核)- 1500(较旧的 java)与 70
我正在使用 angular 1.2 ng-repeat 创建的 div 也包含 ng-click 点击时 ng-click 更新 $scope $scope 中的变化反射(reflect)在使用 $a
这些方法有什么区别 public final void moveCamera(CameraUpdate更新)和public final void animateCamera (CameraUpdate
我尝试了另一篇文章中某人评论中关于如何将树更改为列表的建议。但是,我在某处(或某物)有未声明的变量,所以我列表中的值是 [_G667, _G673, _G679],而不是 [5, 2, 6],这是正确
实现以下场景的最佳方法是什么? 我需要从java应用程序调用/查询包含数百万条记录的数据库表。然后,对于表中的每条记录,我的应用程序应该调用第三方 API 并获取状态字段作为响应。然后我的应用程序应该
只是在编写一些与 java 图形相关的代码,这是我今天的讲座中的非常简单的示例。不管怎样,互联网似乎说更新不会被系统触发器调用,例如调整框架大小等。在这个例子中,更新是由这样的触发器调用的(因此当我只
我是一名优秀的程序员,十分优秀!