欣坚强 2022-04-02 10:53 采纳率: 57.4%
浏览 4
已结题

为什么这样写树状数组是错的呢?调试了好久也没调试出来

题目

img

代码


#include<iostream>
#include<cstdio>

using namespace std;

const int N=32010;

int level[N];
int tr[N];
int n;

int lowbit(int x)
{
    return x&-x;
}

void add(int x)
{
    for(int i=x;i<N;i+=lowbit(i))
        tr[i]++;
}

int sum(int x)
{
    int res=0;
    
    for(int i=x;i;i-=lowbit(i))
        res+=tr[i];
        
    return res;
}

int main()
{
    cin>>n;
    
    while(n--)
    {
        int x,y;
        cin>>x>>y;
        
        x++;
        cout<<x<<endl;
        
        add(x);
        
        level[sum(x)]++;
    }
    
    printf(">>>>>>>>>>>\n");
    
    for(int i=1;i<n;i++)
        cout<<tr[i]<<endl;
        
    printf("...........\n");
    
    for(int i=1;i<=n;i++)
        cout<<level[i]<<endl;
        
    return 0;
}
  • 写回答

0条回答 默认 最新

    报告相同问题?

    问题事件

    • 系统已结题 4月10日
    • 创建了问题 4月2日