면접 준비-C\#버 전의 트 리 배열
5698 단어 트 리 배열
일반 배열 의 수정 은 O(1)계산 과 O(n)이다.
구체 적 인 정 의 는 여 기 를 볼 수 있 습 니 다.http://zh.wikipedia.org/zh-cn/%E6%A0%91%E7%8A%B6%E6%95%B0%E7%BB%84
아니면 이 블 로그: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 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
HDU 5044 - tree - 트 리 체인 분할 + 트 리 배열누 드 체인 으로 나 뉘 어 데이터 가 좀 큰 것 같 습 니 다.선분 트 리 로 T 를 유지 하고 읽 기 마 우 스 를 추가 하면 트 리 배열 이 지나 갈 수 있 습 니 다...........................
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.