zoukankan      html  css  js  c++  java
  • 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
    ",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

  • 相关阅读:
    数据库设计三大范式
    MYSQL语句
    PHP数据库环境配置
    java空心菱形
    java基础练习2
    java基础练习
    java 控制台输入
    java 基础功能
    Java包装
    JS里的DOM操作注意点
  • 原文地址:https://www.cnblogs.com/yxwkf/p/5103089.html
Copyright © 2011-2022 走看看