hdu-4027线段树练习
title: hdu-4027线段树练习
date: 2018-10-10 18:07:11
tags:
- acm
- 算法
- 刷题
categories: - ACM-线段树
概述
这道线段树的题可以说是我这一段时间复习线段树后第一次认认真真的做的第一道线段树的题了吧,,,,
然后,,,看似很简单的题翻车了,,,,QAQ
题意和分析
题意大概就是给你一些数,,然后对[l , r]这个区间里的所有数进行开平方根运算,,,其中还有一些询问[l , r]的区间和,,,
看到一排数列的区间和还有更新询问操作的题型铁定是要用线段树来维护这个数列了,,,
一开始我想着结点保存两个区间和,,一个是现在未更新的区间和,,另一个是每个开方后的区间和,,,然后用lazy来延迟更新,,,然后貌似在更新时这样会少更新,,,最后的答案肯定就不对了,,
最后,,,坑了两个多小时的我还是去找别人的做法了,,,
这道题首先一点就是即使数字很大,,,但是 \(2^{63} - 1\) 也就最多开8次平方根,,,而且开到1时再开平方根还是1,,,,
所以再开到区间所有数都为1时就不再对这个区间更新,,,也就是当 node[rt].sum == node[rt].r - node[rt].l + 1 时就返回上一层,,,这样就减小了更新时的操作,,,
最终的代码,,,
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <algorithm>
using namespace std;
typedef long long ll;
const int maxn = 1e5 + 10;
int n, q;
ll a[maxn];
struct tree
{
int l;
int r;
ll sum;
}node[maxn << 2];
void pushup(int rt)
{
node[rt].sum = node[rt << 1].sum + node[rt << 1 | 1].sum;
}
void build(int rt , int l , int r)
{
node[rt].l = l;
node[rt].r = r;
if (l == r)
{
node[rt].sum = a[l];
return; //要记得return,,,最近写这个总是忘记写
}
int mid = (l + r) >> 1;
build(rt << 1 , l , mid);
build(rt << 1 | 1 , mid + 1 , r);
pushup(rt);
return;
}
void update(int rt , int L , int R)
{
if (node[rt].sum == node[rt].r - node[rt].l + 1)
return; //区间全为1时返回,,,不然会tle
if (node[rt].l == node[rt].r)
{
node[rt].sum = (ll)(sqrt(node[rt].sum)); //直接开方就行了
return;
}
int mid = (node[rt].l + node[rt].r) >> 1;
if (L <= mid) update(rt << 1 , L , R);
if (R > mid) update(rt << 1 | 1 , L , R);
pushup(rt);
return;
}
ll query(int rt , int L , int R)
{
if (L <= node[rt].l && node[rt].r <= R)
{
return node[rt].sum;
}
int mid = (node[rt].l + node[rt].r) >> 1;
ll ans = 0;
if (L <= mid) ans += query(rt << 1 , L , R);
if (R > mid) ans += query(rt << 1 | 1 , L , R);
return ans;
}
int main(int argc, char const *argv[])
{
int i = 0;
while(scanf("%d" , &n) != EOF)
{
printf("Case #%d:\n" , ++i);
for (int i = 1; i <= n; ++i)
scanf("%lld" , &a[i]);
build(1 , 1 , n);
scanf("%d" , &q);
while(q--)
{
int t , l , r;
scanf("%d%d%d" , &t , &l , &r);
if (l > r)
swap(l , r); //l , r不一定保证 l <= r 所以要判断
if (t)
printf("%lld\n" , query(1 , l , r));
else
update(1 , l , r);
}
printf("\n"); //每组测试样例之间加空行
}
return 0;
}
总结
- 没看出来一个数最多开方8次啊,,,
- 还是不能仔细的读题,,,比如那个输入的l , r比如那个每一组测试样例之间加空行
- 想的太多了,,,而且最主要的是还是想着套模板解题,,,而不是就题而选择怎么写
- ,,,,
还是做的题太少了,,还是有点像暑假时见到线段树就套板子,,套板子,,已经好几次套板子是没用的情况了,,,而且除了入门的线段树的题,,,都不是之套板子就能出结果的,,,都要在某些地方加一些判断,,,或者对数据的处理,,,线段树只是众多工具之一啊,,不是万能的呐,,,,
(end)
动手总比只想所得到的多一些,,即使结果不尽人意呐~
hdu-4027线段树练习的更多相关文章
- Can you answer these queries? HDU 4027 线段树
Can you answer these queries? HDU 4027 线段树 题意 是说有从1到编号的船,每个船都有自己战斗值,然后我方有一个秘密武器,可以使得从一段编号内的船的战斗值变为原来 ...
- V - Can you answer these queries? HDU - 4027 线段树 暴力
V - Can you answer these queries? HDU - 4027 这个题目开始没什么思路,因为不知道要怎么去区间更新这个开根号. 然后稍微看了一下题解,因为每一个数开根号最多开 ...
- HDU 4027 <线段树,区间√>
题目连接 题意 给出一个区间,每次把[l,r]内的值√,维护区间和. 坑: £:l会比r大,swap. £: 当f[i].sum=f[i].r-f[i].l+1;,不修改.因为保证每个数都大于等于1, ...
- HDU - 4027 线段树减枝
这题太坑了...满满的都是坑点 1号坑点:给定左右区间有可能是反的...因为题目上说x,y之间,但是没有说明x,y的大小关系(害我一直RE到怀疑人生) 2号坑点:开根号的和不等于和开根号(还好避开了) ...
- hdu 5877 线段树(2016 ACM/ICPC Asia Regional Dalian Online)
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- hdu 3974 线段树 将树弄到区间上
Assign the task Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 3436 线段树 一顿操作
Queue-jumpers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
- hdu 3397 线段树双标记
Sequence operation Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 4578 线段树(标记处理)
Transformation Time Limit: 15000/8000 MS (Java/Others) Memory Limit: 65535/65536 K (Java/Others) ...
- hdu 4533 线段树(问题转化+)
威威猫系列故事——晒被子 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Tot ...
随机推荐
- nodejs压缩
在express中要用到压缩,把某一个文件夹压缩成zip,再返回到客户端提供下载. 用archiver库 var Archiver = require('archiver') router.get(' ...
- Python入门系列教程(五)函数
全局变量 修改全局变量 a=100 def test(): global a a=200 print a 多个返回值 缺省参数 def test3(a,b=1): print a,b test3(a) ...
- 【HDU】2191 多重背包问题
原题目:悼念512汶川大地震遇难同胞——珍惜现在,感恩生活 [算法]多重背包(有限背包) 动态规划 [题解]http://blog.csdn.net/acdreamers/article/detail ...
- zzd 的割草机(Lawnmower)
评测传送门 [题目描述] 已知花坛为一个 n * m 的矩形,草只会长在某些个格子上,zzd 有一个割草机,一开始,zzd 站在(1,1)处,面向(1,m)(面向右).每次 zzd 有两个选择(耗费一 ...
- cassandra数据库
一.下载地址:http://www.apache.org/dyn/closer.lua/cassandra/3.0.11/apache-cassandra-3.0.11-bin.tar.gz 二.安装 ...
- 浅析Postgres中的并发控制(Concurrency Control)与事务特性(上)
转载:https://www.cnblogs.com/flying-tiger/p/9567213.html#4121483#undefined PostgreSQL为开发者提供了一组丰富的工具来管理 ...
- 在c++中实现反射的初步想法
最近在思考如何在c++中实现反射.事情的起因是这样的:我们服务器是用c++开发的,如果需要写一些测试用的GM指令的话,需要编写完GM代码后重新编译并且重启进程,工序繁琐且比较耗时.因此就有了想用脚本( ...
- C# 读取指定文件夹下所有文件
#region 读取文件 //返回指定目录中的文件的名称(绝对路径) string[] files = System.IO.Directory.GetFiles(@"D:\Test" ...
- 九、springcloud之服务网关zuul(二)
一.路由熔断 当我们的后端服务出现异常的时候,我们不希望将异常抛出给最外层,期望服务可以自动进行一降级.Zuul给我们提供了这样的支持.当某个服务出现异常时,直接返回我们预设的信息. 我们通过自定义的 ...
- angular架构
angular架构包括以下部分: 1.模块 2.组件 3.模板 4.元数据 5.数据绑定 6.指令 7.服务 8.依赖注入 9.动画 10.变更检测 11.事件 12.表单 13.HTTP 14.生命 ...