AC题目简解-线段树
线段树:
http://www.notonlysuccess.com/index.php/segment-tree-complete/
鉴于notonlysuccess大牛的博客对于题目的思路写的很简陋,我就稍微补充下。
线段树的基本内容,是通过建二叉树来实现段的存储,最下面的叶子节点是每个值,左孩子和右孩子的父亲则是这个段的信息,依次推上去,实现从1..n的存储。可以通过程序带入样例来模拟这个过程体会。
建树:非叶子节点存储的都是段的值,而每个段,都有一个左边界和右边界。那么就建到叶子节点为止。每次都二分这个段,最后肯定会左边界等于右边界。
更新:如果是点更新则判断点即可,只是在判断该点在哪个区间的时候注意,一下。
查询:查询和更新类似
注意每一个return。
敌兵布阵:很简单的查询和单点更新
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
;
int n;
struct node{
int data,left,right;
void init(int aleft,int aright){
left=aleft;
right=aright;
data=;
}
}tree[MAXN<<];
void pushup(int id){
tree[id].data=tree[id<<].data+tree[id<<|].data;
}
void build(int left,int right,int id){
tree[id].init(left,right);
if(left==right){
scanf("%d",&tree[id].data);
return;//remember here!
}
;
build(left,mid,id<<);
build(mid+,right,id<<|);
pushup(id);
}
int query(int left,int right,int id){
if(left==tree[id].left&&right==tree[id].right)return tree[id].data;
;
);
else
|);
else
)+query(mid+,right,id<<|);
}
void update(int p,int vadd,int id){
if(tree[id].left==tree[id].right){
tree[id].data+=vadd;
return ;
}
;
);
|);
pushup(id);
}
int main(){
int t,a,b;
scanf("%d",&t);
];
;i<=t;i++){
printf("Case %d:\n",i);
scanf("%d",&n);
build(,n,);
]!='E'){
scanf("%d%d",&a,&b);
]){
));break;
);break;
);break;
}
}
}
;
}
hdu1754 I Hate It :单点替换,注意pushup上去
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
;
struct node{
int data,left,right;
void init(int aleft,int aright){
left=aleft;right=aright;
data=;
}
};
node tree[MAXN<<];
inline void pushup(int id){
tree[id].data=max(tree[id<<].data,tree[id<<|].data);
}
void build(int left,int right,int id){
tree[id].init(left,right);//this
if(left==right){
scanf("%d",&tree[id].data);
return;
}
;
build(left,mid,id<<);
build(mid+,right,id<<|);
pushup(id);
}
void update(int p,int value,int id){
if(tree[id].left==tree[id].right){
tree[id].data=value;
return;
}
;
);
|);
pushup(id);
}
int query(int left,int right,int id){
if(left==tree[id].left&&right==tree[id].right)return tree[id].data;
;
);
else
|);
else
),query(mid+,right,id<<|));
}
int main(){
int n,m,a,b;
];
while(scanf("%d%d",&n,&m)!=EOF){
build(,n,);
;i<m;i++){
scanf("%s%d%d",&op,&a,&b);
]==));
);
}
}
;
}
hdu1394 Minimum Inversion Number 题意:求Inversion后的最小逆序数可以看看这篇博客
http://www.cnblogs.com/ziyi--caolu/archive/2013/01/15/2860768.html
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
;
struct node{
int left,right,data;
void init(int aleft,int aright){
left=aleft;
right=aright;
data=;//the num of the value before it
}
};
node tree[MAXN<<];
int n,a[MAXN];
inline void pushup(int id){
tree[id].data=tree[id<<].data+tree[id<<|].data;
}
void build(int left,int right,int id){
tree[id].init(left,right);
if(left==right)return;
;
build(left,mid,id<<);
build(mid+,right,id<<|);
}
void update(int p,int id){
if(tree[id].left==tree[id].right){
tree[id].data=;
return;
}
;
);
|);
pushup(id);
}
int query(int k,int id){
;
if(k<=tree[id].left)return tree[id].data;
;
)+query(k,id<<|);
}
int main(){
while(scanf("%d",&n)!=EOF){
build(,n-,);
;
;i<n;i++){
scanf("%d",&a[i]);
ans+=query(a[i],);
update(a[i],);
}
int minx=ans;
;i<n;i++){
ans+=n-*a[i]-;
if(ans<minx)minx=ans;
}
printf("%d\n",minx);
}
;
}
AC题目简解-线段树的更多相关文章
- AC题目简解-数据结构
A - Japan POJ 3067 要两条路有交叉,(x1,y1)(x2,y2)那么需要满足:(x1-x2)*(y1-y2)<0判断出这是求逆序的问题 树状数组求逆序,先通过自定义的比较器实 ...
- AC题目简解-dp
dp类:A - Bridging signals ZOJ 3627 POJ1631 HDU1950给出一个从1-n的数字排列,求最长上升子序列长度.直接说解法吧.新开一个数组d,d[i]表示的是能构成 ...
- AC题目简解-数论
反素数: HDU2521定义对于任何正整数x,其约数的个数记做g(x).例如g(1)=1,g(6)=4.如果某个正整数x满足:对于任意i(0<i<x),都有g(i)<g(x),则称x ...
- [zoj3813]Alternating Sum 公式化简,线段树
题意:给一个长度不超过100000的原串S(只包含数字0-9),令T为将S重复若干次首尾连接后得到的新串,有两种操作:(1)修改原串S某个位置的值(2)给定L,R,询问T中L<=i<=j& ...
- 线段树详解 (原理,实现与应用)(转载自:http://blog.csdn.net/zearot/article/details/48299459)
原文地址:http://blog.csdn.net/zearot/article/details/48299459(如有侵权,请联系博主,立即删除.) 线段树详解 By 岩之痕 目录: 一:综述 ...
- hdu4973 线段树(题目不错,用了点,段,更新查找还有DFS)
题意: 给你一个初始序列,初始序列长度n,分别为1 2 3 4 5 ....n,有两种操作 (1)D l r 把l_r之间的数据都复制一遍 1 2 3 4 5 6 D 2 4 = 1 2 ...
- [Swust OJ 746]--点在线上(线段树解法及巧解)
题目链接:http://acm.swust.edu.cn/problem/746/ Time limit(ms): 1000 Memory limit(kb): 65535 fate是一个数学大牛 ...
- 题解报告:hdu 1754 I Hate It(线段树)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1754 Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某 ...
- POJ 3667 Hotel(线段树 区间合并)
Hotel 转载自:http://www.cnblogs.com/scau20110726/archive/2013/05/07/3065418.html [题目链接]Hotel [题目类型]线段树 ...
随机推荐
- WCF 配置终结点并调用服务
wcf通过xml文件配置终结点什么的感觉有点小麻烦,个人还是觉得用代码形式配置比较好,当然在发布的时候可能会比较麻烦,需要重新编译... 下面将wcf service寄宿在控制台应用程序中并配置终结点 ...
- printf的格式控制的完整格式
printf的格式控制的完整格式:% - 0 m.n l或h 格式字符下面对组成格式说明的各项加以说明:①%:表示格式说明的起始符号,不可缺少.②-:有-表示左对齐输出,如省略表示右对齐输出 ...
- C# sogou地图API应用总结(二)
在地图上添加自己想要的功能模块 具体代码如下 var map; window.onload = function () { var myOptions = { mapControl: false, / ...
- 【Timers】win服务 定时器
win服务: using System.ServiceProcess; 继承 ServiceBase 即可 定时器: private System.Timers.Timer PushOrderTime ...
- 游刃于MVC、WCF中的Autofac
为了程序的健壮性.扩展性.可维护性,依赖抽象而不是具体实现类等等,于是我选择了Autofac依赖注入容器 就是这个工厂来降低耦合.之前买东西是自己去超市,现在呢 我需要什么东西,他们给送过来直接拿到了 ...
- PHP中日期时间函数date()用法总结
date()是我们常用的一个日期时间函数,下面我来总结一下关于date()函数的各种形式的用法,有需要学习的朋友可参考. 格式化日期date() 函数的第一个参数规定了如何格式化日期/时间.它使用字母 ...
- 【学习总结】【多线程】 安全隐患 & 通讯 & 线程的状态
一.多线程的安全隐患 资源共享 1块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源 比如多个线程访问同一个对象.同一个变量.同一个文件 当多个线程访问同一块资源时,很容易引发数据错乱和数 ...
- 【BZOJ 1006】[HNOI2008]神奇的国度
Description K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系 ...
- python学习笔记30(全局变量的两种解决办法)
先看程序: >>> count = 0 >>> def fuc(count): print count count +=1 >>> for i i ...
- sqlserver mdf ldf文件导入
EXEC sp_attach_db @dbname = '你的数据库名', @filename1 = 'mdf文件路径(包缀名)', @filename2 = 'Ldf文件路径(包缀名 ...