【lc刷题】307 区域和检索 - 数组可修改(BIT)_Day19(68/300)

这篇博客介绍了如何利用Binary Indexed Tree(BIT,又称Fenwick Tree)来实现数组的区间和检索及修改操作。通过示例解释了BIT的建立过程和查询、更新的原理,详细阐述了其在处理update操作时的优势,并提供了相关资源链接供深入学习。
摘要由CSDN通过智能技术生成

68/300

  1. 区域和检索 - 数组可修改
    给定一个整数数组 nums,求出数组从索引 i 到 j (i ≤ j) 范围内元素的总和,包含 i, j 两点。
     
    update(i, val) 函数可以通过将下标为 i 的数值更新为 val,从而对数列进行修改。
     
    示例:
     
    Given nums = [1, 3, 5]
     
    sumRange(0, 2) -> 9
    update(1, 2)
    sumRange(0, 2) -> 8
     
    说明:
     
    数组仅可以在 update 函数下进行修改。
    你可以假设 update 函数与 sumRange 函数的调用次数是均匀分布的。

有update,使用 binary indexed tree(BIT)/ fenwick tree

303 区域和检索 - 数组不可变&304 二维区域和检索 - 矩阵不可变都是用的dp,存前面所有range的和,

而bit就是存部分range的和,一旦遇到update,就不需要迁一发动全身啦,而是动部分身,像这样:
在这里插入图片描述
说白了,就是每个节点都有一个管控范围:
在这里插入图片描述

为了构建这样的效果,我们需要用到二进制(起始位置从20开始,而不是从0开始)。

来看1+2+3+…+16 = 136 如何用BIT储存:
在这里插入图片描述

这样的tree我们是如何建立的?
在这里插入图片描述

移动都是一个一个的,十进制的步长是1,二进制的步长是整串数最右的1
譬如,
十进制的6,下一个是6+1 = 7
二进制的6,表示为(0110)2,找到最右边的1,也就是(0010)2
(0110)2+(0010)2=(1000)2,相当于十进制的8,看上图,6的下一个节点是8
同理,二进制的4和7,下个节点也都是8
节点8的值就是4,6,7三个节点的和。
在这里插入图片描述
当树建好后,我们要问问题了,前8个数的和是多少?

这时候要往前看,看节点8之前还有没有不在它的管控范围下的节点

8: (1000)2 - (1000)2 = 0,也就是节点8自己的值就够了
在这里插入图片描述
按此(超出控制范围的节点)重新构造树,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是我 运行终端代码后的返回,请帮我解释下:shenhaibo@bogon webAssembly % emcc add.c -s WASM=1 -o add.wasm wasm-ld: error: /opt/homebrew/Cellar/emscripten/3.1.40/libexec/cache/sysroot/lib/wasm32-emscripten/libstandalonewasm-nocatch.a(__main_void.o): undefined symbol: main emcc: error: '/opt/homebrew/Cellar/emscripten/3.1.40/libexec/llvm/bin/wasm-ld -o add.wasm /var/folders/hd/zkctfvz128366gcjfw9pgslr0000gn/T/emscripten_temp_0gmz58hs/add_0.o -L/opt/homebrew/Cellar/emscripten/3.1.40/libexec/cache/sysroot/lib/wasm32-emscripten /opt/homebrew/Cellar/emscripten/3.1.40/libexec/cache/sysroot/lib/wasm32-emscripten/crt1.o -lGL -lal -lhtml5 -lstandalonewasm-nocatch -lstubs-debug -lc-debug -ldlmalloc -lcompiler_rt -lc++-noexcept -lc++abi-debug-noexcept -lsockets -mllvm -combiner-global-alias-analysis=false -mllvm -enable-emscripten-sjlj -mllvm -disable-lsr /var/folders/hd/zkctfvz128366gcjfw9pgslr0000gn/T/tmp6m8wb6r0libemscripten_js_symbols.so --strip-debug --export-if-defined=__start_em_asm --export-if-defined=__stop_em_asm --export-if-defined=__start_em_lib_deps --export-if-defined=__stop_em_lib_deps --export-if-defined=__start_em_js --export-if-defined=__stop_em_js --export=emscripten_stack_get_end --export=emscripten_stack_get_free --export=emscripten_stack_get_base --export=emscripten_stack_get_current --export=emscripten_stack_init --export=stackSave --export=stackRestore --export=stackAlloc --export=__errno_location --export-table -z stack-size=65536 --initial-memory=16777216 --max-memory=16777216 --stack-first' failed (returned 1) shenhaibo@bogon webAssembly %
06-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值