HDU 4288 Coder(线段树)
题意:
给定三种操作
1. add x 向序列中添加x,添加之后序列还保持有序
2. del x 删除序列中值为x的元素
3. sum 求下边模5等于3的元素和
思路:
直接暴力也可以过,就是看暴力写的好不好了。用数组直接暴力可过。
暴力代码:
#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std;
const int maxn = ;
typedef long long ll;
int a[maxn]; int main()
{
int n;
while (~scanf("%d", &n))
{
char cmd[];
int d;
int len = ;
while (n--)
{
scanf("%s", cmd);
if (cmd[] == 'a')
{
scanf("%d", &d);
int i;
for (i = len++; i >= ; i--)
{
if (a[i] <= d) break;
a[i + ] = a[i];
}
a[i + ] = d;
}
else if (cmd[] == 'd')
{
scanf("%d", &d);
int i;
for (i = ; i <= len; i++)
if (a[i] == d) break;
for (; i < len; i++)
a[i] = a[i + ];
len--;
}
else
{
ll ans = ;
for (int i = ; i <= len; i += )
ans += (ll)a[i];
printf("%lld\n", ans);
}
}
}
return ;
}
也可以用线段树来维护。先把所有的数据都读进来,然后离散化一下建树。树的每个节点维护一个sum[5],就是模上5之后的余数,还有一个当前区间的有多少个数字的个数。注意:每个节点的sum当中的下边都是对应线段树中该节点的下边来说的。所以叶子节点一定对应1,就是sum[0], 关键就是pushup,因为往上更新的时候,考虑一个父区间,它的左孩子区间对应的sum[i],就是父区间的sum[i],但是右区间的sum[i]对应的不是父区间的sum[i],而是sum[(i + lson.cnt)%5]。所以这样就可以做拉。
#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std;
const int maxn = ;
typedef long long ll;
struct Tree {
int cnt;
ll sum[];
}tree[maxn << ];
int dat[maxn], tmp[maxn];
char cmd[maxn][];
void pushup(int rt)
{
for (int i = ; i < ; i++)
tree[rt].sum[i] = tree[rt<<].sum[i] + tree[rt<<|].sum[((i - tree[rt<<].cnt) % + ) % ];
tree[rt].cnt = tree[rt<<].cnt + tree[rt<<|].cnt;
//当然也可以这么写。
//int j = (i + tree[rt<<1].cnt) % 5;
//tree[rt].sum[j] = tree[rt<<1].sum[j] + tree[rt<<1|1].sum[i];
}
void build(int rt, int l, int r)
{
for (int i = ; i < ; i++) tree[rt].sum[i] = ;
tree[rt].cnt = ;
if (l == r) return;
int mid = (l + r) / ;
build(rt<<, l, mid);
build(rt<<|, mid + , r);
}
void update(int rt, int l, int r, int p, int val, int flag)
{
if (l == r)
{
tree[rt].cnt += flag;
tree[rt].sum[] = val;
return;
}
int mid = (l + r) / ;
if (p <= mid) update(rt<<, l, mid, p, val, flag);
else update(rt<<|, mid + , r, p, val, flag);
pushup(rt);
}
int main()
{
int n;
while (~scanf("%d", &n))
{
int num = ;
for (int i = ; i < n; i++) {
scanf("%s", cmd[i]);
if (cmd[i][] != 's')
{
scanf("%d", &dat[i]);
tmp[num++] = dat[i];
}
}
sort(tmp, tmp + num);
num = unique(tmp, tmp + num) - tmp; build(, , n);
for (int i = ; i < n; i++)
{
int p = lower_bound(tmp, tmp + num, dat[i]) - tmp;
if (cmd[i][] == 's')
printf("%lld\n", tree[].sum[]);
else if (cmd[i][] == 'a')
update(, , n, p, dat[i], );
else update(, , n, p, , -);
}
}
return ;
}
HDU 4288 Coder(线段树)的更多相关文章
- hdu 4288 Coder (线段树+离线)
题意: 刚开始有一个空集合.有三种操作: 1.往集合中加入一个集合中不存在的数 x 2.从集合中删除一个已经存在的数 x 3.计算集合的digest sum并输出. digest sum求 ...
- hdu 4288 离线线段树+间隔求和
Coder Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...
- hdu 4031 attack 线段树区间更新
Attack Time Limit: 5000/3000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Others)Total Subm ...
- hdu 3016 dp+线段树
Man Down Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total S ...
- HDU 4288 Coder (线段树)
Coder 题目:http://acm.hdu.edu.cn/showproblem.php?pid=4288 题意:有三种类型的操作,(1)."add x",表示往集合里加入�数 ...
- HDU 4288 Coder 【线段树+离线处理+离散化】
题意略. 离线处理,离散化.然后就是简单的线段树了.需要根据mod 5的值来维护.具体看代码了. /* 线段树+离散化+离线处理 */ #include <cstdio> #include ...
- HDU 4288 Coder ( 离散化 + 离线 + 线段树 )
这题跟ZOJ 3606的解题思路很相似. 题意:有3中操作:1.向集合中增加一个数x(1≤x≤1e9):2.从集合中删去一个数x(保证这个数存在):3.查询集合中所有位置满足i%5==3的数a[i]的 ...
- HDU 5877 dfs+ 线段树(或+树状树组)
1.HDU 5877 Weak Pair 2.总结:有多种做法,这里写了dfs+线段树(或+树状树组),还可用主席树或平衡树,但还不会这两个 3.思路:利用dfs遍历子节点,同时对于每个子节点au, ...
- HDU4288:Coder(线段树单点更新版 && 暴力版)
Problem Description In mathematics and computer science, an algorithm describes a set of procedures ...
随机推荐
- CSS样式的优先级
1.相同权值情况下,CSS样式的优先级总结来说,就是--就近原则(离被设置元素越近优先级别越高): 内联样式表(标签内部)> 嵌入样式表(当前文件中)> 外部样式表(外部文件中). 2.权 ...
- bzoj 2594: [Wc2006]水管局长数据加强版 动态树
2594: [Wc2006]水管局长数据加强版 Time Limit: 25 Sec Memory Limit: 128 MBSubmit: 934 Solved: 291[Submit][Sta ...
- 15个你不知道的杀手级Google Chrome功能
之前写过一篇我为什么使用Google Chrome浏览器,算是在使用了一段时间的Google Chrome后的一点粗浅认识,最近读到一篇文章15 Killer Google Chrome Featur ...
- c++ 名字粉碎(name mangling)
转自Ibm: Name mangling is the encoding of function and variable names into unique names so that linker ...
- 在前台运行Service
一个前台的 service是被用户强烈关注的从而不会在内存低时被系统杀死.前台 service必须在状态栏上提供一个通知,这个通知被放在"正在进行"区域中,这表示这个通知不能被解除,除非服务停止了或者 ...
- HDU 5927 Auxiliary Set 【DFS+树】(2016CCPC东北地区大学生程序设计竞赛)
Auxiliary Set Time Limit: 9000/4500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Tot ...
- simulink下直接代码生成
连接好DSP,打开Matlab,首先必须要更改环境,要不不能编译通过 输入C2000lib,打开库, 在C2833X DSP Chip Support中添加外设,然后在C2000 Target Pre ...
- UIColor的使用
UIColor主要在设置各个控件的颜色的时候用得到,主要有以下几种方法创建UIColor: 1.使用RGBA创建: greenbluealpha]; 2.直接创建各个常用颜色: [UIColo ...
- (转载)关于having 1=1 和group by 爆表的思考和总结
上次在网上看到一篇关于having 1=1 和group by 爆表注射的文章,看得我晕乎乎的,为了了解其根本原理,我稍微学习了下数据库知识,翻了下资料,但有些资料找不到,于是,开始发挥本天才的思维来 ...
- lvs,haproxy,keepalived,heartbeat
lvs的是通过vrrp协议进行数据包转发的,提供的是4层的负载均衡.特点是效率高,只要你机器网卡抗的住就不是问题. haproxy可以提供4层或7层的数据转发服务,能做到7层的好处是可以根据服务所处的 ...