HDU1754_I Hate It(线段树/单点更新)

HDU1754_I Hate It(线段树/单点更新)

大家好,又见面了,我是全栈君。

解题报告

题意:

思路:

单点替换,区间最值

#include <iostream>
#include <cstring>
#include <cstdio>
#define inf 99999999
using namespace std;
int maxx[808000];
void  update(int root,int l,int r,int p,int v)
{
    int mid=(l+r)/2;
    if(l==r)maxx[root]=v;
    else if(l<r)
    {
        if(p<=mid)update(root*2,l,mid,p,v);
        else update(root*2+1,mid+1,r,p,v);
        maxx[root]=max(maxx[root*2],maxx[root*2+1]);
    }
}
int q_maxx(int root,int l,int r,int ql,int qr)
{
    int mid=(l+r)/2,ans=-inf;
    if(ql<=l&&r<=qr)return maxx[root];
    if(ql<=mid)ans=max(ans,q_maxx(root*2,l,mid,ql,qr));
    if(mid<qr)ans=max(ans,q_maxx(root*2+1,mid+1,r,ql,qr));
    return  ans;
}
int main()
{
    int n,m,i,j,a,ql,qr;
    char str[100];
    while(~scanf("%d%d",&n,&m))
    {
        for(i=1; i<=n; i++)
        {
            scanf("%d",&a);
            update(1,1,n,i,a);
        }
        for(i=1; i<=m; i++)
        {
            scanf("%s%d%d",str,&ql,&qr);
            if(str[0]=='Q')
            {
                printf("%d\n",q_maxx(1,1,n,ql,qr));
            }
            else if(str[0]=='U')
            {
                update(1,1,n,ql,qr);
            }
        }
    }
    return 0;
}

I Hate It

Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 37915    Accepted Submission(s): 15002




Problem Description
非常多学校流行一种比較的习惯。老师们非常喜欢询问,从某某到某某其中,分数最高的是多少。

这让非常多学生非常反感。

无论你喜不喜欢,如今须要你做的是。就是依照老师的要求,写一个程序,模拟老师的询问。当然,老师有时候须要更新某位同学的成绩。

 


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
Hint
Huge input,the C function scanf() will work better than cin

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

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

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


相关推荐

  • ClassLoader cl = getClass().getClassLoader()[通俗易懂]

    ClassLoader cl = getClass().getClassLoader()[通俗易懂]ClassLoadercl=getClass().getClassLoader()getClass():取得当前对象所属的Class对象  getClassLoader():取得该Class对象的类装载器

    2022年5月31日
    30
  • Java对象拷贝_对象的拷贝有几种方法

    Java对象拷贝_对象的拷贝有几种方法大多时候时候使用的是Apache或Spring“BeanUtils,今天,我们来看一下一个更高效的属性拷贝方式:BeanCopier。https://github.com/cglib/cglibhttps://github.com/cglib/cglib/blob/master/cglib/src/main/java/net/sf/cglib/beans/BeanCopier.java首先梳理出来现在有哪些对象拷贝的方式:Apache的BeanUtils:BeanUtils是Apach.

    2022年9月4日
    2
  • python写helloworld代码_helloworld代码怎么写?

    python写helloworld代码_helloworld代码怎么写?展开全部java:java”>publicclasshelloworld{publicstaticvoidmain(String[]args){System.out.println(“Helloworld!”);}}python2:print”Helloworld!”python3:print(“Helloworld!”)C/C++:#includeintmain(…

    2022年7月16日
    17
  • Docker中Web集群迁移及共享数据

    Docker中Web集群迁移及共享数据

    2021年5月29日
    98
  • uniapp父子组件传值

    uniapp父子组件传值在父组件中引入子组件父传子(props)在子类props里定义接收参数在子类标签写上引用然后在父类写上准备传递的参数此时,父组件传到子组件的值,就会覆盖默认背景色子传父($emit)需要首先在子类组件定义事件在子类写上触发事件在父类引用标签上写上在子类$emit里面定义的方法名,以及接收方法然后点击子类触发,就可以传值给父类注意:1.父传子用props;…

    2022年5月17日
    299
  • fork join框架原理_jalor6框架教程

    fork join框架原理_jalor6框架教程声明:本篇博客是在阅读了引用博客的两篇文章后做了简短的概括与归纳,只作为自己笔记文章目录一、思想二、工作窃取算法三、demo用例四、关键组件ForkJoinPoolForkJoinTaskForkJoinWorkerThreadWorkQueue五、Fork/Join运行流程图任务提交创建线程signalWork方法任务执行六、引用博客一、思想Fork/Join是Java7提供的并行执行…

    2022年9月20日
    0

发表回复

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

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