问题描述:

给定一个数列,要求对指定区间内所有数开方,输出查询区间和

输入:

有很多个测试用例,每个用例第一行输出一个整数N,表示数列有N个数,1<=N<=100000;第二行输入N个整数E,E<2e63;第三行输入整数M,表示M种操作,1<=M<=100000;之后的M行,每行输入3个整数T X Y。T=0,表示修改,将区间[L,R]内所有数开方(开方结果向下取整);T=1表示查询,查询区间[L,R]的区间和。

输出:

对于每个查询操作输出结果,并打印编号,每个操作打印一行(注意这里有坑)。

这属于线段树的简单应用,我们直接看代码

#include<iostream>
using namespace std; #define ll long long
const int MAX = 1e5 + 5;
int n, m, ind=0; int ls(int i) { return i << 1; }
int rs(int i) { return i << 1 | 1; }
int ship[MAX]; //线段树
struct Tree {
int l;
int r;
ll sum;
}tree[MAX*4]; void pushup(int i) {
tree[i].sum = tree[ls(i)].sum+ tree[rs(i)].sum;
} //建立线段树
void build(int i, int l, int r) {
tree[i].l = l;
tree[i].r = r;
if (l == r) { //到达叶子节点
tree[i].sum = ship[l];
return;
}
int mid = (l + r) >> 1;
build(ls(i), l, mid);
build(rs(i), mid + 1, r);
//到达叶子节点后递归回根节点的路上,更新沿路节点
pushup(i);
} //节点更新函数
void update(int i, int l, int r, int x, int y) {
if (tree[i].sum == (r - l + 1)) return; //剪枝1,这种情况说明区间中的数字已经被开方七次以上,区间中所有数字都为1,没必要继续开方
if (l == r) {
tree[i].sum = sqrt(ship[l]);
return;
}
if (tree[i].l<x || tree[i].r>y) return; //剪枝2,要保证更新范围在区间内
int mid = (l + r) >> 1;
if (x <= mid) update(ls(i), l, mid, x, y);
if (y > mid) update(rs(i), mid + 1, r, x, y);
//更新完之后,到达叶子节点递归回根节点的路上还需要更新沿路节点
pushup(i);
} //查询函数,注意该函数返回类型,如果不放心建议将i,x,y都改为long long类型
//由于开方操作没办法做到一步完成多步所以并没有使用lazy_tag标记
ll query(int i, int x, int y) {
if (tree[i].l >= x && tree[i].r <= y) return tree[i].sum;
if (tree[i].l > y || tree[i].r < x) return 0;
ll ans=0;
/*
也可以写成:
int mid=(l+r)>>1;
if(x<=mid) ans+=query(ls(i),x,y);
if(y>mid) ans+=query(rs(i),x,y);
感觉格式更加工整,效果是一样的
*/
if (tree[ls(i)].r >= x) ans += query(ls(i), x, y);
if (tree[rs(i)].l <= y) ans += query(rs(i), x, y);
return ans;
} //线段树:build函数 uodate函数 pushdown函数 addtag函数 pushup函数
int main() {
while (~scanf(" % d", &n)) {
ll ans;
int t, x1, y1, x, y;
for (int i = 1; i <= n; i++) {
cin >> ship[i];
}
build(1, 1, n);
cin >> m;
cout << ++ind;
for (int i = 1; i <= m; i++) {
cin >> t >> x1 >> y1;
x = min(x1, y1);
y = max(x1, y1);
if (t == 0) {
update(1, 1, n, x, y);
}
if (t == 1) {
ans = query(1, x, y);
cout << ans << endl;;
}
}
//这是个坑,
cout << endl;
}
return 0;
}

线段树can you answer these queries-------hdu4027的更多相关文章

  1. (线段树 区间查询更新) Can you answer these queries? -- hdu--4027

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=4027 分析:因为这个操作是把一个数变成平方根,所以显得略棘手,不过如果仔细演算的话会发现一个2^64数的 ...

  2. Can you answer these queries?---hdu4027

    题目链接 有n个数:当操作为1时求L到R的和: 当操作为0时更新L到R为原来的平方根: 不过如果仔细演算的话会发现一个2^64数的平方根开8次也就变成了 1,所以也更新不了多少次,所以可以每次更新到底 ...

  3. Can you answer these queries?-HDU4027 区间开方

    题意: 给你n个数,两个操作,0为区间开方,1为区间求和 链接:http://acm.hdu.edu.cn/showproblem.php?pid=4027 思路: 如果当该区间的数都为1,我们没必要 ...

  4. HDU4027 Can you answer these queries? —— 线段树 区间修改

    题目链接:https://vjudge.net/problem/HDU-4027 A lot of battleships of evil are arranged in a line before ...

  5. HDU4027 Can you answer these queries? 线段树

    思路:http://www.cnblogs.com/gufeiyang/p/4182565.html 写写线段树 #include <stdio.h> #include <strin ...

  6. HDU4027 Can you answer these queries?(线段树 单点修改)

    A lot of battleships of evil are arranged in a line before the battle. Our commander decides to use ...

  7. Can you answer these queries?(HDU4027+势能线段树)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4027 题目: 题意:n个数,每次区间更新将其数值变成它的根号倍(向下取整),区间查询数值和. 思路:易 ...

  8. kuangbin专题七 HDU4027 Can you answer these queries? (线段树)

    A lot of battleships of evil are arranged in a line before the battle. Our commander decides to use ...

  9. GSS4 2713. Can you answer these queries IV 线段树

    GSS7 Can you answer these queries IV 题目:给出一个数列,原数列和值不超过1e18,有两种操作: 0 x y:修改区间[x,y]所有数开方后向下调整至最近的整数 1 ...

  10. SPOJ 1557. Can you answer these queries II 线段树

    Can you answer these queries II Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 https://www.spoj.com/pr ...

随机推荐

  1. ABC358

    A link -- 点击查看代码 #include<bits/stdc++.h> using namespace std; string s,t; signed main(){ cin & ...

  2. 浅谈 I/O 与 I/O 多路复用

    1.基础知识 网络编程里常听到阻塞IO.非阻塞IO.同步IO.异步IO等概念,总听别人聊不如自己下来钻研一下.不过,搞清楚这些概念之前,还得先回顾一些基础的概念. 下面说的都是Linux环境下,跟Wi ...

  3. 如何在本地修改Hosts文件设置域名访问?

    网站在未上线的时候,我们一般会在本地搭建Web环境并安装WordPress来设计页面.测试插件.数据备份.网站搬家. 为了能够在本地通过域名访问网站,就需要在修改hosts文件来绑定域名,方法如下: ...

  4. 我出一道面试题,看看你能拿 3k 还是 30k!

    大家好,我是程序员鱼皮.欢迎屏幕前的各位来到今天的模拟面试现场,接下来我会出一道经典的后端面试题,你只需要进行 4 个简单的选择,就能判断出来你的水平是新手(3k).初级(10k).中级(15k)还是 ...

  5. Java基础学习知识点框架(详细)

    //学习网站 Java研发技术学习路线_飞月程序人生-CSDN博客_java开发学习路线 Java后端技术栈梳理 - 知乎 harrywfl/JavaGuide: [Java学习+面试指南] 一份涵盖 ...

  6. 一款基于Fluent设计风格、现代化的WPF UI控件库

    前言 今天大姚给大家分享一款基于Fluent设计风格.开源(MIT License).现代化的WPF UI控件库,它提供直观的设计.主题.导航和全新的沉浸式控件,全部都是原生且无缝地集成在一起:WPF ...

  7. Jmeter函数助手28-urldecode

    urldecode函数用于解码application/x-www-form-urlencoded字符串. String to encode in URL encoded chars:填入applica ...

  8. 【Java / JavaScript】AES加密解密

    Java封装的AES加密解密工具类: 几个重要的参数信息 - 需要指定一个密钥串sKey 密钥内容自定义 数字 + 字母 + 特殊符号 - 加密方式为 AES - AES下面的模式ECB - ECB下 ...

  9. 【SqlServer】02 SSMS工具基本使用入门

    之前的安装中除了SqlServer,还有一个SSMS管理工具 数据库的访问依赖于工具 SSMS提供了两种登陆方式: 创建用户: 删除用户: 创建数据库: 删除数据库: 创建表: 设置表的字段,字段名称 ...

  10. 使用AI技术(单张图片或文字)生产3D模型 —— Ai生成3D模型的时代来了

    地址: https://www.bilibili.com/video/BV1A2421P7pH/ 视频用到的工具voxcraft体验地址:https://voxcraft.ai/