[关闭]
@Metralix 2017-04-22T23:45:48.000000Z 字数 1173 阅读 818

A - Binary Simulation

线段树


题目大意

给出一行字符串,只包含 0 和 1,给出操作选项;I: 为把一个区间内字符反向 0 变为 1,1 变为 0;Q:查询第 i 个字符。

解题思路

线段树模板题...区间更新反转次数,奇数次反转
  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. #define lson l, mid, rt << 1
  5. #define rson mid + 1, r, rt << 1 | 1
  6. using namespace std;
  7. int const MAX = 1e5 + 5;
  8. int chg[MAX << 2], lazy[MAX << 2];
  9. char s[MAX];
  10. int n, len;
  11. void PushDown(int rt)
  12. {
  13. if(lazy[rt])
  14. {
  15. chg[rt << 1] += lazy[rt];
  16. chg[rt << 1 | 1] += lazy[rt];
  17. lazy[rt << 1] += lazy[rt];
  18. lazy[rt << 1 | 1] += lazy[rt];
  19. lazy[rt] = 0;
  20. }
  21. return;
  22. }
  23. void Update(int L, int R, int l, int r, int rt)
  24. {
  25. if(L <= l && r <= R)
  26. {
  27. chg[rt] ++;
  28. lazy[rt] ++;
  29. return;
  30. }
  31. int mid = (l + r) >> 1;
  32. PushDown(rt);
  33. if(L <= mid)
  34. Update(L, R, lson);
  35. if(mid < R)
  36. Update(L, R, rson);
  37. }
  38. int Query(int L, int R, int l, int r, int rt)
  39. {
  40. if(L == l && r == R)
  41. return chg[rt];
  42. int mid = (l + r) >> 1, ans = 0;;
  43. PushDown(rt);
  44. if(L <= mid)
  45. return Query(L, R, lson);
  46. if(mid < R)
  47. return Query(L, R, rson);
  48. return ans;
  49. }
  50. int main()
  51. {
  52. int T;
  53. scanf("%d", &T);
  54. for(int ca = 1; ca <= T; ca++)
  55. {
  56. scanf("%s %d", s + 1, &n);
  57. len = strlen(s + 1);
  58. memset(chg, 0, sizeof(chg));
  59. memset(lazy, 0, sizeof(lazy));
  60. printf("Case %d:\n", ca);
  61. while(n --)
  62. {
  63. char op[2];
  64. scanf("%s", op);
  65. if(op[0] == 'I')
  66. {
  67. int l, r;
  68. scanf("%d %d", &l, &r);
  69. Update(l, r, 1, len, 1);
  70. }
  71. else
  72. {
  73. int x, num = 0;
  74. scanf("%d", &x);
  75. num = Query(x, x, 1, len, 1);
  76. if(num & 1)
  77. printf("%d\n", (s[x] == '0') ? 1 : 0);
  78. else
  79. printf("%d\n", (s[x] == '0') ? 0 : 1);
  80. }
  81. }
  82. }
  83. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注