面试准备 - 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;
        }
    }
}
复制代码

 

posted on   听说读写  阅读(597)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示