面试准备 - C# 版本的树状数组
树状数组 计算 任意连续N个值的和的时间复杂度为Log(n) 修改也是Log(n)
而普通数组修改是O(1) 计算和是O(n)
具体定义可以看这里:http://zh.wikipedia.org/zh-cn/%E6%A0%91%E7%8A%B6%E6%95%B0%E7%BB%84
或者看这个Blog:http://dongxicheng.org/structure/binary_indexed_tree/
这东西刚刚好可以解决 编程之美里面的 1.7光影切割问题
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Clover.Algoritms.DataStructure { public class TreeArray { private double[] items; private double[] data; public TreeArray(double[] data) { if (data == null || data.Length == 0) throw new ArgumentNullException("data"); this.items = new double[data.Length]; this.data = data; for (int i = 1; i <= items.Length; i++) { int start = i - Lowbit(i); double sum = 0; while (start < i) { sum += data[start]; start++; } items[i - 1] = sum; } } public double Sum(int k) { double ret = 0; while (k > 0) { ret += items[k - 1]; k -= Lowbit(k); } return ret; } public void Update(int k, int value) { int x = k - 1; var oldValue = this.data[x]; this.data[x] = value; for (int i = x; i < items.Length; i += Lowbit(i + 1)) { items[i] = items[i] - oldValue + value; } } public static int Lowbit(int i) { return i & -i; } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库