原题传送门

这道题实际和GSS4是一样的,只是输入方式有点区别

GSS4传送门

这道题暴力就能过qaq(这里暴力指线段树)

数据比较水

开方修改在线段树中枚举叶节点sqrt

查询区间和线段树基本操作

这就可以ac

下面有两个优化,没在代码中体现

1.加开方的懒标记

2.最大的数很小,只要开方6次就可以变成1

所以线段树中再记录区间最大值

当最大值是1时,就可以不用开方

暴力的代码

#include <bits/stdc++.h>
using namespace std;
const int MAXN=100005;
long long a[MAXN];
long long f[MAXN<<2];
long long read(long long &x)
{
long long f=1;char ch=getchar();
x=0;
while(ch<'0' || ch>'9')
{
if(ch=='-')
f=-1;
ch=getchar();
} while(ch>='0' && ch<='9')
{
x=x*10+ch-'0';
ch=getchar(); }
return x*f;
}
int readline(int &x)
{
int f=1;char ch=getchar();
x=0;
while(ch<'0' || ch>'9')
{
if(ch=='-')
f=-1;
ch=getchar();
}
while(ch>='0' && ch<='9')
{
x=x*10+ch-'0';
ch=getchar();
}
return x*f;
}
void build(int root,int left,int right)
{
if(left==right)
{
f[root]=a[left];
return;
}
int mid=(left+right)/2;
build(2*root,left,mid);
build(2*root+1,mid+1,right);
f[root]=f[2*root]+f[2*root+1];
} void update(int root,int left,int right,int qleft,int qright)
{
int mid,ans,i;
if(right-left+1==f[root])
return;
if(left==right)
{
f[root]=sqrt(f[root]);
return;
}
mid=(left+right)/2;
if(qleft<=mid)
update(2*root,left,mid,qleft,qright);
if(mid<qright)
update(2*root+1,mid+1,right,qleft,qright);
f[root]=f[root*2]+f[root*2+1];
}
long long query(int root,int left,int right,int qleft,int qright)
{
long long ans=0;
if(qleft<=left&&right<=qright)
return f[root];
int mid=(left+right)/2;
if(qleft<=mid)
ans=query(2*root,left,mid,qleft,qright);
if(mid<qright)
ans+=query(2*root+1,mid+1,right,qleft,qright);
return ans;
}
int main()
{
int n,i,x,y,j,way,k=0,m;
scanf("%d",&n);
for(i=1;i<=n;i++)
read(a[i]);
build(1,1,n);
readline(m);
for(i=1;i<=m;i++)
{
readline(way);readline(x);readline(y);
if(x>y)
swap(x,y);
if(way==1)
printf("%lld\n",query(1,1,n,x,y));
else
update(1,1,n,x,y);
}
return 0;
}

【题解】 Luogu P4145 上帝造题的七分钟2 / 花神游历各国的更多相关文章

  1. luogu P4145 上帝造题的七分钟2 / 花神游历各国 维护区间和&&区间开根号

    因为开根号能使数字减小得非常快 所以开不了几次(6次?)很大的数就会变成1..... 所以我们可以维护区间最大值,若最大值>1,则继续递归子树,暴力修改叶节点,否则直接return (好像也可以 ...

  2. [Luogu P4145] 上帝造题的七分钟2 / 花神游历各国

    题目链接 题目简要:我们需要一个能支持区间内每一个数开方以及区间求和的数据结构. 解题思路:说道区间修改区间查询,第一个想到的当然就是分块线段树.数据范围要用long long.本来我是看到区间这两个 ...

  3. 洛谷P4145 上帝造题的七分钟2 / 花神游历各国(重题:洛谷SP2713 GSS4 - Can you answer these queries IV)

    题目背景 XLk觉得<上帝造题的七分钟>不太过瘾,于是有了第二部. 题目描述 "第一分钟,X说,要有数列,于是便给定了一个正整数数列. 第二分钟,L说,要能修改,于是便有了对一段 ...

  4. 洛谷P4145 上帝造题的七分钟2/花神游历各国 [树状数组,并查集]

    题目传送门 题目背景 XLk觉得<上帝造题的七分钟>不太过瘾,于是有了第二部. 题目描述 "第一分钟,X说,要有数列,于是便给定了一个正整数数列. 第二分钟,L说,要能修改,于是 ...

  5. 洛谷P4145——上帝造题的七分钟2 / 花神游历各国

    题目背景 XLk觉得<上帝造题的七分钟>不太过瘾,于是有了第二部. 题目描述 "第一分钟,X说,要有数列,于是便给定了一个正整数数列. 第二分钟,L说,要能修改,于是便有了对一段 ...

  6. 洛谷 P4145 上帝造题的七分钟2 / 花神游历各国

    洛谷 这题就是区间开根号,区间求和.我们可以分块做. 我们记布尔数组vis[i]表示第i块中元素是否全部为1. 因为显然当一个块中元素全部为1时,并不需要对它进行根号操作. 我们每个块暴力开根号,因为 ...

  7. P4145 上帝造题的七分钟2 / 花神游历各国(线段树区间开平方)

    有点意思,不需要什么懒标记之类的东西,因为一个数无论怎样开平方,最后取整的结果必然会是1,所以我们不妨用最大值来维护,若区间最大值不为1,就暴力修改,否则不用管. #include<bits/s ...

  8. P4145 上帝造题的七分钟2 / 花神游历各国

    思路 每个数不会被开方超过log次,对每个数暴力开方即可 代码 #include <algorithm> #include <cstring> #include <cst ...

  9. day1 晚上 P4145 上帝造题的七分钟2 / 花神游历各国 线段树

    #include<iostream> #include<cstdio> #include<cmath> using namespace std; ; struct ...

随机推荐

  1. [LeetCode] 1. Two Sum_Easy

    Given an array of integers, return indices of the two numbers such that they add up to a specific ta ...

  2. Cocos Creator scrollview添加事件的两种方法

    scrollview添加事件 方法一这种方法添加的事件回调和使用编辑器添加的事件回调是一样的,通过代码添加, 你需要首先构造一个 cc.Component.EventHandler 对象,然后设置好对 ...

  3. LineRenderer组建实现激光效果

    在射击游戏中狙击一般都有一个红外线的效果.比如

  4. MyBatis基础入门《十》添加数据

    MyBatis基础入门<十>添加数据 描述: 修改了实体类:TblClient.java,将其字段:cbirthday 由String类型改成了Date类型. TblClient.java ...

  5. Linux MySQL数据库文件同步及数据库备份

    Mysql数据库链接 mysql -uroot -p -hdatacenter.jiaofukeyan.com -P33069 1.文件同步 rsync -avz --delete root@(需要同 ...

  6. 删掉centos原有的openjdk并安装sun jdk

    [环境变量]删掉centos原有的openjdk并安装sun jdk   一.卸载原有openjdk rpm -qa | grep java 之后,将展示出来的全部卸载掉,我这里是5个 rpm -e ...

  7. JavaScript-年月日转换12小时制

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  8. 使用js Math.random()函数生成n到m间的随机数字

    何使用js生成n到m间的随机数字,主要目的是为后期的js生成验证码做准备,Math.random()函数返回0和1之间的伪随机数   摘要: 本文讲解如何使用js生成n到m间的随机数字,主要目的是为后 ...

  9. hdu5302 构造

    题意:给你一个无向图,它的边要么是黑色要么是白色,且图上的每个点最多与两个黑边两个白边相连.现在,Demon将图分成两部分,一部分包含所有的黑边,另一部分包括所有的白边,给你白边图中度为0的点的数量w ...

  10. JDBC操作数据库步骤

    2018-11-04  20:23:24开始写 1.加载驱动程序(Class.forName) 2.建立连接获取数据库连接对象(DriverManager.getConnection) 3.向数据库发 ...