HDU1166 树状数组入门
2020-12-13 14:37
阅读:285
标签:getch put += ios style ane complex pre tac
/**/ #include#include > #include#include #include #include #include #include #include string> #include #include typedef long long LL; typedef unsigned long long ULL; using namespace std; bool Sqrt(LL n) { return (LL)sqrt(n) * sqrt(n) == n; } const double PI = acos(-1.0), ESP = 1e-10; const LL INF = 99999999999999; const int inf = 999999999, N = 5e4 + 24; int T, n, w, a[N], C[N]; char s[6]; int lowbit(int x) { return (x & -x); } void Add(int i, int w) { while(i n) { C[i] += w; i += lowbit(i); } } int sum(int i) { int sum = 0; while(i > 0) { sum += C[i]; i -= lowbit(i); } return sum; } int main() { //freopen("in.txt", "r", stdin); //freopen("out.txt", "w", stdout); scanf("%d", &T); for(int kase = 1; kase ) { scanf("%d", &n); // memset(a, 0, sizeof a); memset(C, 0, sizeof C); for(int i = 0; i 0; for(int i = 1; i "%d", &w); Add(i, w); } printf("Case %d:\n", kase); // if(s[0] == ‘E‘) continue; // else if(s[0] == ‘A‘) { // } // else if(s[0] == ‘S‘) Sub(); // else if(s[0] == ‘Q‘) Query(); int u, v; // getchar(); while(scanf("%s", s), strcmp(s, "End") != 0) { // printf("\ns = %s\n", s); scanf("%d%d", &u, &v); if(strcmp(s, "Query") == 0) printf("%d\n", sum(v) - sum(u - 1)); if(strcmp(s, "Add") == 0) Add(u, v); if(strcmp(s, "Sub") == 0) Add(u, -v); } } return 0; } /* input: output: modeling: methods: complexity: summary: */
Sample Input
1 10 1 2 3 4 5 6 7 8 9 10
Query 1 3
Add 3 6
Query 2 7
Sub 10 2
Add 6 3
Query 3 10
End
Sample Output
Case 1:
6
33
59
HDU1166 树状数组入门
标签:getch put += ios style ane complex pre tac
原文地址:https://www.cnblogs.com/000what/p/11565881.html
上一篇:SpringMVC详细流程(一)
下一篇:数据结构-冒泡排序
评论
亲,登录后才可以留言!