摘要: 添加 lsum[ ] , rsum[ ] , msum[ ] 来记录从左到右的区间,从右到左的区间和最大的区间;#include#define lson l,m,rty?x:y;}void pushup(int l,int r,int rt){ int m=(l+r)/2; lsum[r... 阅读全文
posted @ 2015-07-18 17:10 sweat123 阅读(156) 评论(0) 推荐(0) 编辑
摘要: 由于坐标可能很大,此时需要离散化,将值转化为对应的坐标。#include#includeusing namespace std;#define lson l,m,rt=L&&R>=r) { sum[rt]=1; if(!mark[c]) { ... 阅读全文
posted @ 2015-07-18 15:46 sweat123 阅读(189) 评论(0) 推荐(0) 编辑
摘要: 给n个数字 U表示第A个数改为B。A是从0开始。Q输出最大的递增序列个数。考虑左边,右边,和最大的。#include#define lson l,m,rty?x:y;}int min(int x,int y){ return x=p) updata(p,c,lson); e... 阅读全文
posted @ 2015-07-18 15:02 sweat123 阅读(226) 评论(0) 推荐(0) 编辑
摘要: 求矩阵的并,也就是要求所有的面积。那可以吧总的图形按照矩阵来切割。使其为一块一块。输入的时候用坐标表示,这里扫描线从下到上扫描。初始时让下面的边为1,上面的为-1;用一条先从下面开始想上扫描。遇到更新线段树,加入该条边,为-1时就除去改变。这样从下到上一遍扫描就可以得到线段的长度。从下到上的过程中,... 阅读全文
posted @ 2015-07-18 14:18 sweat123 阅读(226) 评论(0) 推荐(0) 编辑
摘要: /* 不是叶子节点 ,且cnt=1.注意这里,cnt=1确切的意义是什么, 应该是,可以确定,这个区间被完全覆盖了1次, 而有没有被完全覆盖两次或以上则不知道无法确定,那么怎么怎么办了, 只要加上t[lch].s + t[rch].s 即,看看左右孩子区间被覆盖了一次或以上... 阅读全文
posted @ 2015-07-18 14:07 sweat123 阅读(167) 评论(0) 推荐(0) 编辑
摘要: 简单线段树hdu1166 1 #include 2 #define lson l,m,rt m)43 ret += Query(L,R,rson);44 else if(m >= R)45 ret += Query(L,R,lson);46 else4... 阅读全文
posted @ 2015-07-13 13:53 sweat123 阅读(165) 评论(0) 推荐(0) 编辑
摘要: 原来听到树状数组这名字感觉很难,很高大上。学了一下发现不难。而且很好。 普通的数组修改某个值耗费为O(1),输出和为O(n);而树状数组为O(logn);lowbit(x){ return x&(-x);}返回的是x二进制最后一位1的位置; 有公式:cn=a(n-a^k+1)+.........+a 阅读全文
posted @ 2015-06-07 18:58 sweat123 阅读(251) 评论(0) 推荐(0) 编辑
摘要: 1 #include 2 #include 3 using namespace std; 4 struct node 5 { 6 int id; 7 int val; 8 friend bool operatorb.id;15 }16 }17 };1... 阅读全文
posted @ 2015-06-07 16:36 sweat123 阅读(199) 评论(0) 推荐(0) 编辑
摘要: 1 #include<stdio.h> 2 #include<queue> 3 using namespace std; 4 5 6 struct node 7 { 8 friend bool operator< (node x,node y) 9 { 10 return x.pre>y.pre;/ 阅读全文
posted @ 2015-06-07 14:04 sweat123 阅读(190) 评论(0) 推荐(0) 编辑
摘要: //点双连通分量的求解//就是通过tarjan算法求出关节点时,与关节点的子树就是一个连通分量,可以通过画图得到//所以可以将与顶点u有关的边放到栈中,然后一但满足low[v]>=dfn[u](表面点u是割点)(注释:由于dfs,已经建好了u//的子树,所以栈中有顶点u的子树),就可以进行退栈,直到... 阅读全文
posted @ 2015-06-04 14:02 sweat123 阅读(494) 评论(0) 推荐(0) 编辑