题目大意:给出y值升序的一些点,定义一个点的level值为它左下方的点的数量,求每一个level有多少个点。
思路:由于y值是升序的,那么后面的点只要判断是否x值比前面的大就行了。那么就用树状数组维护。
CODE:
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define MAX 50000 using namespace std; int cnt,fenwick[MAX]; int ans[MAX]; inline void Initialize(); inline void Fix(int x); inline int GetSum(int x); int main() { while(scanf("%d",&cnt) != EOF) { Initialize(); for(int x,y,i = 1;i <= cnt; ++i) { scanf("%d%d",&x,&y); x++; Fix(x); ans[GetSum(x)]++; } for(int i = 1;i <= cnt; ++i) printf("%d\n",ans[i]); } return 0; } inline void Initialize() { memset(fenwick,0,sizeof(fenwick)); memset(ans,0,sizeof(ans)); } inline void Fix(int x) { for(;x < MAX;x += x&-x) fenwick[x]++; } inline int GetSum(int x) { int re = 0; for(;x;x -= x&-x) re += fenwick[x]; return re; }
原文地址:http://blog.csdn.net/jiangyuze831/article/details/40112039