B – I Hate It

B – I Hate It

B – I Hate It

B – I Hate It

很多学校流行一种比较的习惯。老师们很喜欢询问,从某某到某某当中,分数最高的是多少。 
这让很多学生很反感。 

不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问。当然,老师有时候需要更新某位同学的成绩。

Input

本题目包含多组测试,请处理到文件结束。 
在每个测试的第一行,有两个正整数 N 和 M ( 0<N<=200000,0<M<5000 ),分别代表学生的数目和操作的数目。 
学生ID编号分别从1编到N。 
第二行包含N个整数,代表这N个学生的初始成绩,其中第i个数代表ID为i的学生的成绩。 
接下来有M行。每一行有一个字符 C (只取’Q’或’U’) ,和两个正整数A,B。 
当C为’Q’的时候,表示这是一条询问操作,它询问ID从A到B(包括A,B)的学生当中,成绩最高的是多少。 
当C为’U’的时候,表示这是一条更新操作,要求把ID为A的学生的成绩更改为B。 

Output

对于每一次询问操作,在一行里面输出最高成绩。

Sample Input

5 6
1 2 3 4 5
Q 1 5
U 3 6
Q 3 4
Q 4 5
U 2 9
Q 1 5

Sample Output

5
6
5
9

这题也是基本的线段树,在上一题的基础上,多了一个求节点最大值的函数,并且把query的查找函数的功能由求这一区间的和改为求这一区间的最大值,中间也一直错,还好现在对线段树的基本代码是熟练了

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
const  int maxn =  200000+100;
int tree[maxn*4],ae[maxn];
void zuida(int node)
{
	tree[node] = max(tree[node*2],tree[node*2+1]);
}
void build(int node, int l, int r)
{
	if(l==r)
	{
		tree[node]=ae[l];
		return ;
	}
	int mid =(l + r)/ 2;
	build(node*2,l,mid);
	build(node*2+1,mid+1,r);
	tree[node]=tree[node*2]+tree[node*2+1];
	zuida(node);
}
void update(int x,int indx,int node, int l, int r)
{
	if(l==r)
	{
		tree[node]=x;
		return ;
	}
	int mid=(l+r)/2;
	if(indx<=mid)  update(x,indx,node*2,l,mid);
	if(indx>mid) update(x,indx,node*2+1,mid+1,r);
	tree[node]=tree[node*2]+tree[node*2+1];
	zuida(node);
}
int query(int x,int y,int node,int l, int r)
{
	if(x<=l&&y>=r)
	{
		return tree[node];
	}
	int mid = (l+r)/2;
	int sum=0;//zaizhe1liangbian
	if(x<=mid) sum=max(sum,query(x, y, node*2,l,mid));
	if(y>mid)  sum=max(sum,query(x, y, node*2+1,mid+1,r));
	return sum;
}
int main()
{
	int m, n;
	int a, b;
	while(cin>>n>>m){
	for(int i=1; i<=n; i++)  scanf("%d",&ae[i]);
	build(1,1,n);
	char s[maxn];
	while(m--)
	{
		scanf("%s",s);
		getchar();
		scanf("%d %d",&a,&b);
		if(s[0]=='Q')
		{
			printf("%d\n",query(a,b,1,1,n));
		}
		if(s[0]=='U')	update(b,a,1,1,n);
		
	}
	}
	return 0;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114889.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 常见的web前端性能优化方法总结「建议收藏」

    常见的web前端性能优化方法总结「建议收藏」首先,我们要了解一下,前端优化的目的是什么从用户角度,优化能够让页面加载得更快、对用户的操作响应更快,给用户提供更为友好的体验。从服务商角度,优化能够减少页面请求数、或者减小请求所占带宽,节省资源。大概有如下优化方法,我们看一下:一、页面内容优化减少http请求次数减少DNS查询次数避免页面跳转缓存ajax延迟加载(一般用在图片多的页面中,滚动时才加载)预加载减少D…

    2022年6月29日
    26
  • [转载] 七龙珠第一部——第104话 悟空复活吧

    [转载] 七龙珠第一部——第104话 悟空复活吧

    2021年8月24日
    48
  • ubuntu安装pycharm后找不到在哪_ubuntu安装类型

    ubuntu安装pycharm后找不到在哪_ubuntu安装类型1、下载PycharmLINUX版本2、复制到虚拟机,并解压在当前文件夹,右键安装包,点击“ExtractHere”3、打开终端,进入pycharm-2020.1.1/bin;4、执行pycharm.sh命令文件,开始安装;sh./pycharm.sh5.激活6.创建快捷方式6.1在/usr/share/applications创建一个文件:pycharm.desktop(touch,gedit,nano指令等)cd/usr/share/applicationssudoge

    2022年9月27日
    0
  • 手机发布版sha1怎么获取_androidstudio导出项目zip

    手机发布版sha1怎么获取_androidstudio导出项目zip申请key必须用发布版的SHA1及MD51.打包出来apk;2.将apk修改后缀为.rar文件后解压;3.进入解压后的META-INF目录,该目录下会存在文件CERT.RSA;4.在该目录下打开cmd,输入命令:keytool-printcert-fileCERT.RSA若提示输入密码,则输入android后回车…

    2022年8月10日
    3
  • 编程语言的主要类型

    转:编程语言的主要类型,声明式编程,命令式编程()和函数式编程的区别2016年12月18日11:59:07 xuqinggangsls 阅读数:5242 标签:&#

    2022年3月29日
    41
  • sin傅里叶变换公式_傅里叶变换公式(傅里叶变换常用公式)

    sin傅里叶变换公式_傅里叶变换公式(傅里叶变换常用公式)一般傅里叶变换与反变换的公式是成对儿给出的。1、如果正变换前有系数1/2*π,则反变换前无系数2、如果正变换前无系数,则反变换前有系数1/2*π3、正、反变换前.1.傅里叶正变换2.傅里叶逆变换常用的就可以了问题是我找不到教材书了啊大概最常用的输10个左右就ok了连续傅里叶变换一般情况下,若“傅立叶变换”一词的前面未加任何限定语,则指的是“连续傅里叶变换”。“连续傅里叶变换”将平方…

    2022年7月17日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号