HDUOJ---1754 I Hate It (线段树之单点更新查区间最大值)

I Hate It

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


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
代码: 线段树之单点更新
代码:
 1 #include<stdio.h>
 2 #define maxn 200001
 3 int aa[maxn<<2];
 4 struct node
 5 {
 6   int lef,rig,maxc;
 7   int mid(){ return lef+((rig-lef)>>1); }
 8 };
 9 node seg[maxn<<2];
10 void build(int left ,int right ,int p)
11 {
12     seg[p].lef=left;
13     seg[p].rig=right;
14     seg[p].maxc=0;
15     while(left==right)
16     {
17       seg[p].maxc=aa[left];
18       return ;
19     }
20     int mid=seg[p].mid();
21     build(left,mid,p<<1);
22     build(mid+1 ,right,p<<1|1);
23     if(seg[p<<1].maxc<seg[p<<1|1].maxc)
24         seg[p].maxc=seg[p<<1|1].maxc;
25     else
26         seg[p].maxc=seg[p<<1].maxc;
27 }
28 void updata(int pos ,int p,int val)
29 {
30     if(seg[p].lef==seg[p].rig)
31          {
32            seg[p].maxc=val ;
33            return ;
34          }
35     int mid=seg[p].mid();
36     if(pos<=mid) updata(pos,p<<1,val);
37     else if(pos>mid) updata(pos,p<<1|1,val);
38     if(seg[p<<1].maxc<seg[p<<1|1].maxc)
39           seg[p].maxc=seg[p<<1|1].maxc;
40     else seg[p].maxc=seg[p<<1].maxc;
41 }
42 int query(int be,int en ,int p)
43 {
44     if(be<=seg[p].lef&&seg[p].rig<=en)
45           return seg[p].maxc;
46     int res2=0,res1=0;
47     int mid=seg[p].mid();
48     if(be<=mid) res1=query(be,en ,p<<1);
49     if(en>mid)  res2=query(be,en ,p<<1|1);
50     if(res1<res2) return res2;
51     else  return res1;
52 }
53 int main()
54 {
55     int nn,mm,i,j,sa,sb;
56     char str[3];
57     while(scanf("%d%d",&nn,&mm)!=EOF)
58     {
59         for(i=1;i<=nn;i++)
60           scanf("%d",&aa[i]);
61           build(1,nn,1);
62         while(mm--)
63         {
64             scanf("%s%d%d",str,&sa,&sb);
65             if(*str=='Q')
66               printf("%d\n",query(sa,sb,1));
67             else  updata(sa,1,sb);
68         }
69     }
70   return 0;
71 }
View Code

 

代码:

 1 #include<cstdio>
 2 #include<cstring>
 3 const int maxn=200005;
 4 int aa[maxn];
 5 struct node
 6 {
 7     int lef,rig;
 8     int max;
 9     int mid(){
10       return lef+((rig-lef)>>1);
11     }
12 };
13  node str[maxn<<2];
14 inline int max(int a,int b)
15 {
16    return a>b?a:b;
17 }
18  void Build(int left ,int right,int pos)
19  {
20     str[pos].lef=left;
21     str[pos].rig=right;
22     str[pos].max=0;
23     if(left==right){
24       str[pos].max=aa[left];
25       return ;
26     }
27     int mid=str[pos].mid();
28     Build(left,mid,pos<<1);
29     Build(mid+1,right,pos<<1|1);
30     str[pos].max = max( str[pos<<1].max , str[pos<<1|1].max );
31  }
32  void Update(int ps,int pos,int val)
33  {
34      if(str[pos].lef==ps&&str[pos].rig==ps){
35         str[pos].max=val;    //将这个数值更新
36        return ;
37      }
38      int mid=str[pos].mid();
39      if(mid>=ps) Update(ps,pos<<1,val);
40      else  if(mid<ps)  Update(ps,pos<<1|1,val);
41      str[pos].max=max(str[pos<<1].max,str[pos<<1|1].max);
42  }
43  int  Query(int st,int en,int pos)
44  {
45     if(str[pos].lef>=st&&str[pos].rig<=en){
46         return str[pos].max;
47      }
48     int mid=str[pos].mid();
49     int p1=0,p2=0;
50     if(mid>=st) p1=Query(st,en,pos<<1);
51     if(mid<en)  p2=Query(st,en,pos<<1|1);
52     return max(p1,p2);
53  }
54 
55  int main()
56  {
57    int n , m,cc,dd;
58    char ss[2];
59    while(scanf("%d%d",&n,&m)!=EOF)
60    {
61       for(int i=1;i<=n;i++)
62        scanf("%d",aa+i);
63        Build(1,n,1);
64        while(m--)
65        {
66         scanf("%s %d%d",ss,&cc,&dd);
67         if(*ss=='Q')
68           printf("%d\n",Query(cc,dd,1));
69         else Update(cc,1,dd);
70        }
71    }
72    return 0;
73  }
View Code

 

转载于:https://www.cnblogs.com/gongxijun/p/3686014.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/377114.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 把数字转换成链表

例如&#xff1a;123456转换成 1 -> 2 -> 3-> 4-> 5-> 6 View Code static LinkedList<int> CovertIntToLinkedList(int num){Stack<int> stack new Stack<int>();LinkedList<int> result new LinkedList<int>();while (num!0…

《MySQL 8.0.22执行器源码分析(4.1)Item_sum类以及聚合》

Item_sum类用于SQL聚合函数的特殊表达式基类。 这些表达式是在聚合函数&#xff08;sum、max&#xff09;等帮助下形成的。item_sum类也是window函数的基类。 聚合函数&#xff08;Aggregate Function&#xff09;实现的大部分代码在item_sum.h和item_sum.cc 聚合函数限制 不…

Java 性能优化实战记录(2)---句柄泄漏和监控

前言: Java不存在内存泄漏, 但存在过期引用以及资源泄漏. (个人看法, 请大牛指正) 这边对文件句柄泄漏的场景进行下模拟, 并对此做下简单的分析.如下代码为模拟一个服务进程, 忽略了句柄关闭, 造成不能继续正常服务的小场景. 1 public class FileHandleLeakExample {2 3 p…

骑士游历问题问题_骑士步行问题

骑士游历问题问题Problem Statement: 问题陈述&#xff1a; There is a chessboard of size NM and starting position (sx, sy) and destination position (dx,dy). You have to find out how many minimum numbers of moves a knight goes to that destination position? 有…

Android基础之用Eclipse搭建Android开发环境和创建第一个Android项目(Windows平台)...

一、搭建Android开发环境 准备工作&#xff1a;下载Eclipse、JDK、Android SDK、ADT插件 下载地址&#xff1a;Eclipse:http://www.eclipse.org/downloads/ JDK&#xff1a;http://www.oracle.com/technetwork/java/javase/downloads/jdk7u9-downloads-1859576.html Android SD…

《dp补卡——01背包问题》

目录01背包[416. 分割等和子集](https://leetcode-cn.com/problems/partition-equal-subset-sum/)[1049. 最后一块石头的重量 II](https://leetcode-cn.com/problems/last-stone-weight-ii/)[494. 目标和](https://leetcode-cn.com/problems/target-sum/)01背包 1、dp数组以及…

用JavaScript往DIV动态添加内容

参考&#xff1a;http://zhidao.baidu.com/link?url6jSchyqPiEYCBoKdOmv52YHz9r7MTBms2pK1N6ptOX1kaR2eg320mlW1Sr6n36hpOeOadBxC2rWWGuhZPbms-K <div id"show"></div>要填充的数据为: 这是一个测试例子.jquery&#xff1a;$(function(){ var data …

《dp补卡——完全背包问题》

N件物品和一个最多能背重量为W的背包。第i件物品的重量为weight[i]&#xff0c;得到的价值是value[i]。每件物品都有无限个(可以放入背包多次)&#xff0c;求解将哪些物品装入背包里物品价值总和最大。 01背包和完全背包唯一不同在于遍历顺序上。 01背包的核心代码&#xff1a…

《dp补卡——多重背包》

多重背包简介&#xff1a; 有N种物品和一个容量为V的背包。第i种物品最多有Mi件可用&#xff0c;每件耗费的空间为Ci&#xff0c;价值为Wi。求解将哪些物品装入背包可使得这些物品耗费的空间总和不超过背包容量&#xff0c;且价值总和最大。 将Mi件摊开&#xff0c;就是一个01背…

CocoaAsyncSocket 套接字

CocoaAsyncSocket 套接字 https://github.com/robbiehanson/CocoaAsyncSocket Asynchronous socket networking library for Mac and iOS 用于iOS以及Mac的异步套接字网络库。 TCP GCDAsyncSocket and AsyncSocket are TCP/IP socket networking libraries. Here are the key…

谷歌浏览器设置缓存方法

谷歌浏览器设置缓存方法&#xff1a; 1、在桌面Google Chrome快捷方式&#xff0c;目标&#xff1a;找到 C:\Users\Splendid\AppData\Local\…\Application\chrome.exe 在这后面加上-Disk-Cache-Dir”Z:\TEMP” 注意: -Disk前面有空格&#xff0c;”Z:\TEMP” 是文件存放在Z盘T…

《dp补卡——子序列问题》

目录300. 最长递增子序列674. 最长连续递增序列718. 最长重复子数组1143. 最长公共子序列53. 最大子序和392. 判断子序列115. 不同的子序列583. 两个字符串的删除操作72. 编辑距离647. 回文子串 &#xff08;与 5.最长回文子串思路差不多&#xff09;516. 最长回文子序列300. 最…

《leetcode : 647. 回文子串 思考分析双指针解法》

647. 回文子串 如何确定是回文串&#xff1a; 找中心然后往两边扩散&#xff0c;判断是否对称即可。 在遍历中心点的时候&#xff0c;注意中心点可以是一个元素也可以是两个元素。 class Solution { public:int cal_two_extend(const string& s,int i,int j,int n){int re…

explain用法

explain用法 EXPLAIN SELECT …… 变体&#xff1a; 1. EXPLAIN EXTENDED SELECT …… 将执行计划“反编译”成SELECT语句&#xff0c;运行SHOW WARNINGS 可得到被MySQL优化器优化后的查询语句 2. EXPLAIN PARTITIONS SELECT …… 用于分区表的EXPLAIN 执行计划包含的信息 id…

转:Google论文之三----MapReduce

文章来自于&#xff1a;http://www.cnblogs.com/geekma/p/3139823.html MapReduce&#xff1a;大型集群上的简单数据处理 摘要 MapReduce是一个设计模型&#xff0c;也是一个处理和产生海量数据的一个相关实现。用户指定一个用于处理一个键值&#xff08;key-value&#xff09;…

《DBNotes:Join算法的前世今生》

目录NestLoopJoin算法Simple Nested-Loop JoinIndex Nested-Loop JoinBlock Nested-Loop JoinBatched Key AccessHash Join算法In-Memory Join(CHJ)On-Disk Hash Join参考链接在8.0.18之前&#xff0c;MySQL只支持NestLoopJoin算法&#xff0c;最简单的就是Simple NestLoop Joi…

UNITY3D与iOS交互解决方案

原地址&#xff1a;http://bbs.18183.com/thread-456979-1-1.html 本帖最后由 啊,将进酒 于 2014-2-27 11:17 编辑 “授人以鱼&#xff0c;不如授人以渔”&#xff0c;以UNITY3D调用iOS版的91SDK为例&#xff0c;利用C# / C / OBJ-C交互原理,本文将详细介绍UNITY3D与iOS之间交互…

AP in R

AP聚类算法是目前十分火的一种聚类算法&#xff0c;它解决了传统的聚类算法的很多问题。不仅简单&#xff0c;而且聚类效果还不错。这里&#xff0c;把前两天学习的AP算法在R语言上面的模拟&#xff0c;将个人笔记拿出来与大家分享一下&#xff0c;不谈AP算法的原理&#xff0c…

nginx 模块解析

nginx的模块非常之多&#xff0c;可以认为所有代码都是以模块的形式组织&#xff0c;这包括核心模块和功能模块&#xff0c;针对不同的应用场合&#xff0c;并非所有的功能模块都要被用到&#xff0c;附录A给出的是默认configure&#xff08;即简单的http服务器应用&#xff09…

《LeetcodeHot100非困难题补录》

最近比较闲&#xff0c;也比较焦虑&#xff0c;刷刷题吧 目录11. 盛最多水的容器22. 括号生成31. 下一个排列48. 旋转图像49. 字母异位词分组56. 合并区间75. 颜色分类79. 单词搜索114. 二叉树展开为链表141. 环形链表148. 排序链表152. 乘积最大子数组169. 多数元素207. 课程表…