HDU 1754 I Hate It (段树单点更新)

HDU 1754 I Hate It (段树单点更新)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

Problem Description
很多学校更受欢迎的习惯。

老师们真的很喜欢问。从XX XX到其中,的是多少。
这让非常多学生非常反感。

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

 

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

 

感觉没什么好说的,这是我线段树的入门题,感觉效果非常好

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>

#define L(x) (x<<1)
#define R(x) (x<<1|1)
#define MID(x,y) ((x+y)>>1)
using namespace std;
#define N 200005

struct stud{
int le,ri;
int va;
}f[N*4];

int a[N];

void pushup(int pos)
{
    f[pos].va=max(f[L(pos)].va,f[R(pos)].va);
}

void build(int pos,int le,int ri)
{
    f[pos].le=le;
    f[pos].ri=ri;

    if(le==ri)
    {
      f[pos].va=a[le];
      return ;
    }
    int mid=MID(le,ri);

    build(L(pos),le,mid);
    build(R(pos),mid+1,ri);

   pushup(pos);
}

void update(int pos,int le,int ri)
{
    if(f[pos].le==le&&f[pos].ri==le)
    {
        f[pos].va=ri;
        return ;
    }

    int mid=MID(f[pos].le,f[pos].ri);

    if(mid>=le)
        update(L(pos),le,ri);
    else
        update(R(pos),le,ri);

    pushup(pos);
}

int query(int pos,int le,int ri)
{
   if(f[pos].le>=le&&f[pos].ri<=ri)
   {
       return f[pos].va;
   }

   int mid=MID(f[pos].le,f[pos].ri);

   if(mid>=ri)
    return query(L(pos),le,ri);
   else
    if(mid<le)
    return query(R(pos),le,ri);
   else
      return max(query(L(pos),le,mid),query(R(pos),mid+1,ri));
}

int main()
{
    int n,m,i;

    while(~scanf("%d%d",&n,&m))
    {
        for(i=1;i<=n;i++)
            scanf("%d",&a[i]);

         build(1,1,n);

        char c[10];
        int le,ri;

        while(m--)
        {
            scanf("%s%d%d",c,&le,&ri);

            if(c[0]=='Q')
                printf("%d\n",query(1,le,ri));
            else
                update(1,le,ri);
        }
    }
    return 0;
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

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

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

(0)
上一篇 2022年1月7日 下午12:00
下一篇 2022年1月7日 下午1:00


相关推荐

  • ubuntu防火墙常用命令

    ubuntu防火墙常用命令ubuntu 防火墙常用命令

    2025年11月3日
    4
  • 最低公共祖先java_满族的祖先是

    最低公共祖先java_满族的祖先是原题链接题目描述如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先。输入格式第一行包含三个正整数 N,M,SN,M,S,分别表示树的结点个数、询问的个数和树根结点的序号。接下来 N-1N−1 行每行包含两个正整数 x, yx,y,表示 xx 结点和 yy 结点之间有一条直接连接的边(数据保证可以构成树)。接下来 MM 行每行包含两个正整数 a, ba,b,表示询问 aa 结点和 bb 结点的最近公共祖先。输出格式输出包含 MM 行,每行包含一个正整数,依次为每一个询问的结果。输入

    2022年8月8日
    8
  • iPad如何越狱?4.2.1完美越狱教程 一 (DFU 绿霸越狱)[通俗易懂]

    iPad如何越狱?4.2.1完美越狱教程 一 (DFU 绿霸越狱)[通俗易懂] 4.2.1完全越狱图文教程.如何用Cydia安装程序  Cydia“源安装”方式安装程序  Cydia“搜索安装”方式安装程序  Cydia“分类安装”方式安装程序  如何卸载用Cydia安装的程序  如何更新用Cydia安装的程序  关于SHSH的说明  Cydia总结.如何用Installous4直接安装程序?…

    2026年1月29日
    6
  • JS设置CSS样式的几种方式

    JS设置CSS样式的几种方式JS 设置 CSS 样式的几种方式 1 直接设置 style 的属性某些情况下用这个设置 import 值无效如果属性有 号 就需要使用驼峰命名法 如 textAlign 如果想保留 号 就使用中括号 如 element style text align 100px element style height 100px 2 直接设置属性 只能用于某些属性 相关样式会

    2026年3月19日
    2
  • 【原】Github系列之一:一起做仿天气类应用中的实时模糊效果LiveBlur

    【原】Github系列之一:一起做仿天气类应用中的实时模糊效果LiveBlur

    2021年9月4日
    55
  • 记忆七层协议

    记忆七层协议很好得记忆从上至下 是 应 表 会 传 网 数 链 物 直接背下去 ok 七个关键字上面是 osi 模型还有就是如何用 Tcp ip 记忆也是如上图显示得一样 纯手打 自己多画一画 就会记忆深刻些

    2026年3月18日
    2

发表回复

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

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