原题传送门

这道题实际和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] 603. Consecutive Available Seats_Easy tag: SQL

    Several friends at a cinema ticket office would like to reserve consecutive available seats.Can you ...

  2. [LeetCode] 607. Sales Person_Easy tag: SQL

    Description Given three tables: salesperson, company, orders.Output all the names in the table sales ...

  3. 服务器--apache启用多个端口的方法

    apache启用多个端口的方法 使用本地ip:端口号,或者修改hosts文件+域名的方法来进行本地多站点web调试. 注意这里是用apache 不是iis 1.安装好AppServ2.5.9软件 官网 ...

  4. 38.html----相对于父元素的fixed定位的实现

    之前在项目中,遇到了一个场景,需要实现相对于父元素的fixed定位:在父元素内拖动滚动条时,"fixed"定位的元素不能滑动,在外层拖动滚动条时,父元素及父元素内的所有元素跟着一起 ...

  5. 21.JQ的监听事件(点击div外面可以让它消失)

    JQ的监听事件(点击div外面可以让它消失) //监听整个页面 $(document).bind("click", function() { //给需要的对象赋予事件 $(&quo ...

  6. tfs分支操作

    1.在代码管理器中找到代码项 右击——分支与合并——分支——默认所有选项——确定. 2.可能刚打出的分支为红色,签入,修改代码,待测试后代码合并到主干中(下拉选出他的上级,一般为主干),删除分支. 3 ...

  7. Rpgmakermv(18)GALV RollCredits

    原文: Galv's Roll Credits ---------------------------------------------------------------------------- ...

  8. I/O流的概念和流类库的结构

    概念: 程序的输入指的是从输入文件将数据传送给程序,程序的输出指的是从程序将数据传送给输出文件. C++输入输出包含以下三个方面的内容: 1.对系统指定的标准设备的输入和输出.即从键盘输入数据,输出到 ...

  9. Java多线程-----volatile关键字详解

       volatile原理     Java语言提供了一种稍弱的同步机制,即volatile变量,用来确保将变量的更新操作通知到其他线程.当把变量声明为volatile类型后, 编译器与运行时都会注意 ...

  10. Windows 下VC++6.0制作、使用动态库和静态库

    Windows 下VC++6.0制作.使用动态库和静态库 一.VC++6.0制作.使用静态库 静态库制作 1.如图一在VC++6.0中new一个的为win32 static library工程并新建一 ...