hdu 1754 块状链表 单点修改+单点查询

经典的线段树题目,也可以用块状链表做。

  1 #include <iostream>
  2 #include <cstring>
  3 #include <cstdio>
  4 #include <cmath>
  5 using namespace std;
  6 
  7 const int N = 200000;
  8 const int M = 800;
  9 int n, m, tot;
 10 
 11 int max( int a, int b )
 12 {
 13     return a > b ? a : b;
 14 }
 15 
 16 struct Block
 17 {
 18     int num[M];
 19     int size, maxn;
 20     void init()
 21     {
 22         size = maxn = 0;
 23     }
 24     void push( int tmp )
 25     {
 26         num[size++] = tmp;
 27         if ( tmp > maxn ) maxn = tmp;
 28     }
 29 } bl[M];
 30 
 31 void update( int pos, int v )
 32 {
 33     int cur = 0;
 34     while ( pos > bl[cur].size )
 35     {
 36         pos -= bl[cur].size;
 37         cur++;
 38     }
 39     bl[cur].num[pos - 1] = v;
 40     bl[cur].maxn = 0;
 41     for ( int i = 0; i < bl[cur].size; i++ )
 42     {
 43         bl[cur].maxn = max( bl[cur].maxn, bl[cur].num[i] );
 44     }
 45 }
 46 
 47 int query( int l, int r )
 48 {
 49     int cur = 0, inc = r - l;
 50     while ( l > bl[cur].size )
 51     {
 52         l -= bl[cur].size;
 53         cur++;
 54     }
 55     int ncur = cur;
 56     r = l + inc;
 57     while ( r > bl[ncur].size )
 58     {
 59         r -= bl[ncur].size;
 60         ncur++;
 61     }
 62     int ans = 0;
 63     for ( int i = cur + 1; i <= ncur - 1; i++ )
 64     {
 65         ans = max( ans, bl[i].maxn );
 66     }
 67     if ( cur == ncur )
 68     {
 69         for ( int j = l - 1; j < r; j++ )
 70         {
 71             ans = max( ans, bl[cur].num[j] );
 72         }
 73     }
 74     else
 75     {
 76         for ( int j = l - 1; j < bl[cur].size; j++ )
 77         {
 78             ans = max( ans, bl[cur].num[j] );
 79         }
 80         for ( int j = 0; j < r; j++ )
 81         {
 82             ans = max( ans, bl[ncur].num[j] );
 83         }
 84     }
 85     return ans;
 86 }
 87 
 88 int main()
 89 {
 90     while ( scanf("%d%d", &n, &m) != EOF )
 91     {
 92         tot = 0;
 93         bl[tot].init();
 94         int ps = sqrt((double)n);
 95         for ( int i = 0; i < n; i++ )
 96         {
 97             int tmp;
 98             scanf("%d", &tmp);
 99             if ( bl[tot].size == ps )
100             {
101                 tot++;
102                 bl[tot].init();
103             }
104             bl[tot].push(tmp);
105         }
106         char op[2];
107         int a, b;
108         while ( m-- )
109         {
110             scanf("%s%d%d", op, &a, &b);
111             if ( op[0] == 'Q' )
112             {
113                 printf("%d\n", query( a, b ));
114             }
115             else
116             {
117                 update( a, b );
118             }
119         }
120     }
121     return 0;
122 }

对于这个题操作种类很少,可以写成二维数组的形式,看起来更简洁。

 1 #include <iostream>
 2 #include <cstring>
 3 #include <cstdio>
 4 #include <cmath>
 5 using namespace std;
 6 
 7 const int M = 550;
 8 int b[M][M];
 9 int maxn[M];
10 int n, q;
11 int ps;
12 
13 int max( int a, int b )
14 {
15     return a > b ? a : b;
16 }
17 
18 void setv( int i, int j, int v )
19 {
20     b[i][j] = v;
21     maxn[i] = max( maxn[i], b[i][j] );
22 }
23 
24 int query( int l, int r )
25 {
26     int cur = l / ps, ncur = r / ps;
27     l = l % ps, r = r % ps;
28     int ret = -1;
29     for ( int i = cur + 1; i <= ncur - 1; i++ )
30     {
31         ret = max( ret, maxn[i] );
32     }
33     if ( cur != ncur )
34     {
35         for ( int j = l; j < ps; j++ )
36         {
37             ret = max( ret, b[cur][j] );
38         }
39         for ( int j = 0; j <= r; j++ )
40         {
41             ret = max( ret, b[ncur][j] );
42         }
43     }
44     else
45     {
46         for ( int j = l; j <= r; j++ )
47         {
48             ret = max( ret, b[cur][j] );
49         }
50     }
51     return ret;
52 }
53 
54 void update( int pos, int val )
55 {
56     int i = pos / ps, j = pos % ps;
57     b[i][j] = val;
58     maxn[i] = -1;
59     for ( int k = 0; k < ps && i * ps + k < n; k++ )
60     {
61         maxn[i] = max( maxn[i], b[i][k] );
62     }
63 }
64 
65 int main ()
66 {
67     ps = 500;
68     while ( scanf("%d%d", &n, &q) != EOF )
69     {
70         memset( maxn, -1, sizeof(maxn) );
71         for ( int i = 0; i < n; i++ )
72         {
73             int tmp; scanf("%d", &tmp);
74             setv( i / ps, i % ps, tmp );
75         }
76         char op[2];
77         int a, b;
78         while ( q-- )
79         {
80             scanf("%s%d%d", op, &a, &b);
81             if ( op[0] == 'Q' )
82             {
83                 a--; b--;
84                 printf("%d\n", query( a, b ));
85             }
86             else
87             {
88                 a--;
89                 update( a, b );
90             }
91         }
92     }
93     return 0;
94 }

 

转载于:https://www.cnblogs.com/huoxiayu/p/4471049.html

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

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

相关文章

靶场练习第四天~vulnhub靶场之Lazysysadmin

靶机下载链接: https://pan.baidu.com/s/1MMkgaYLRc78YX4s6nvqdjQ 提取码: djpm 信息收集 查看kali的IP 使用nmap 192.168.101.0/24 探测靶机IP 发现开放445端口&#xff0c;并且开放的服务microsoft-ds。可以用enum4linux工具来扫描共享文件&#xff0c;使用方法: enum4linux…

关于代码手写UI,xib和StoryBoard

代码手写UI 这种方法经常被学院派的极客或者依赖多人合作的大型项目大规模使用。Geek们喜欢用代码构建UI&#xff0c;是因为代码是键盘敲出来的&#xff0c;这样可以做到不开IB&#xff0c;手不离开键盘就完成工作&#xff0c;可以专注于编码环境&#xff0c;看起来很cool很高效…

ODAC(V9.5.15) 学习笔记(十)TVirtualTable

名称 类型 说明 Options TVirtualTableOptions 选择项&#xff0c;包括&#xff1a; voPersistentData&#xff1a;在数据集关闭时不处理其相关数据内容 voStored&#xff1a;设计期对数据集的处理以及录入的数据将保存在DFM文件中 AddField 增加一个字段&#xff0c…

SQLSERVER如何获取一个数据库中的所有表的名称、一个表中所有字段的名称

1.查询数据库中的所有数据库名&#xff1a; 1 SELECT Name FROM Master..SysDatabases ORDER BY Name 2.查询某个数据库中所有的表名&#xff1a; 1 SELECT Name FROM SysObjects Where XTypeU ORDER BY Name 3.查询表结构信息&#xff1a; 1 SELECT (case when a.colorder1 …

靶场练习第五天~vulnhub靶场之basic_pentesting_1

一、信息收集 1.主机发现 靶机下载链接: https://pan.baidu.com/s/143q3cbZG6-8y8kMk51Lc_Q 提取码: i8hv &#xff08;1&#xff09;Netdiscover&#xff1a;专用的二层发现工具&#xff0c;拥有主动和被动发现两种方式 具体操作如下&#xff0c;查看一下kali的ip 然后使用…

计算机网络学习笔记(二) 计算机网络结构

什么是网络结构&#xff1f; n 网络边缘: 主机网络应用 n 接入网络&#xff0c;物理介质:有线或无线通信链路 n 网络核心&#xff08; 核心网络&#xff09; :互联的路由器&#xff08;或分组转发设备&#xff09;网络之网…

Javascript常用的设计模式详解

Javascript常用的设计模式详解 阅读目录 一&#xff1a;理解工厂模式二&#xff1a;理解单体模式三&#xff1a;理解模块模式四&#xff1a;理解代理模式五&#xff1a;理解职责链模式六&#xff1a;命令模式的理解&#xff1a;七&#xff1a;模板方法模式八&#xff1a;理解ja…

靶场练习第六天~vulnhub靶场之Lampiao

靶机下载链接: https://pan.baidu.com/s/1h0uiwvBkX8iXFyMAO23e1A 提取码: 2kjp 一、信息收集 1.靶机发现 &#xff08;1&#xff09;靶机lampiao与kali均为NAT模式 ,Kali的 IP为192.168.101.10, 扫描网段用命令nmap -sp192.168.101.0/24&#xff0c;发现靶机ip为192.168.10…

生成百度地图 如何弄

http://api.map.baidu.com/lbsapi/creatmap/index.html转载于:https://www.cnblogs.com/qinqiu/p/4476747.html

内存泄露从入门到精通三部曲之排查方法篇

最原始的内存泄露测试 重复多次操作关键的可疑的路径&#xff0c;从内存监控工具中观察内存曲线&#xff0c;是否存在不断上升的趋势且不会在程序返回时明显回落。这种方式可以发现最基本&#xff0c;也是最明显的内存泄露问题&#xff0c;对用户价值最大&#xff0c;操作难度小…

靶场练习第七天~vulnhub靶场之mrRobot

靶机下载链接: 百度网盘 请输入提取码 提取码: sqv3 一、主机发现 1.用ifconfig查看kali的ip&#xff0c;因为kali和靶机都开启了NAT模式&#xff0c;使用namp -sP 192.168.101.0/24探测靶机ip 二、信息收集 1.使用nmap扫描靶机 使用nmap -A 192.168.101.108 &#xff0c;查…

JAVA第二次试验

北京电子科技学院&#xff08;BESTI&#xff09; 实 验 报 告 课程&#xff1a;Java程序设计 班级&#xff1a;1352 姓名&#xff1a;潘俊洋 学号&#xff1a;20135230 成绩&#xff1a; 指导教师:娄嘉鹏 实验日期:2015.5.4 实验密级&#xff1a…

【转】怎么样从一个疯狂下载者成为一个学习者!!!值得反省下的问题·~~

为了方便广大网友&#xff0c;各种网站也应运而生。当网络的建设和发展正进行的如火如荼&#xff0c;喧闹之中&#xff0c;搭配学习这壶美酒的&#xff0c;竟是一瓶名叫资料下载的毒药&#xff0c;更糟糕的是&#xff0c;美酒和毒药已经被灌到了同一个杯子里&#xff0c;浑然一…

靶场练习第八天~vulnhub靶场之CH4INRULZ_v1.0.1

一、前期准备 1.靶机下载 链接: 百度网盘 请输入提取码 提取码: z37y 2.用命令ifconfig查看kali 二、信息收集 1.主机发现&#xff0c;使用nmap命令 具体使用方法&#xff1a;nmap -sP 192.168.101.0/24 2.查看该靶机开放了哪些端口 nmap -A 192.168.101.109 直接访问80端…

C# 不支持关键字: “.;database”。

解决方案分析:这个一定是链接字符串有问题&#xff0c;核对web.config 和程序的字符串是否有误转载于:https://www.cnblogs.com/louby/p/5208986.html

TImus 1073 Square Country DP

题意&#xff1a;给出一个数n(1<n<60000),这个数可以写成一些数的平方的和&#xff0c; 问对于n&#xff0c;最少可以分成多少个数的平方的和。 比如&#xff1a;n344&#xff0c;则34418*184*42*2&#xff0c;输出3. dp[i]表示i这个数最少可以分成多少个数的平方的和。 …

vulnhub靶机获取不到ip

1.启动靶机&#xff0c;出现如下图所示&#xff0c;按e 2.进入如下图所示时&#xff0c;将ro 替换为 rw signie init/bin/bash 3.按下Ctrl键X键&#xff0c;重启服务进入如下界面 4.查看当前网卡IP信息 ip a 5.编辑网卡配置文件vi /etc/network/interfaces 6.发现网卡名字与刚…

apache整合tomcat部署集群

近日&#xff0c;由于公司项目需要&#xff0c;所以学习了apache整合tomcat以及集群的一些知识。 所以做下笔记日后回顾可以用到。 apache只有处理静态事物的能力&#xff0c; 而tomcat的强项就是处理动态的请求&#xff0c;所以apache和tomcat整合相互取长补短&#xff0c;由a…

Cpk

CPK&#xff1a;Complex Process Capability index 的缩写&#xff0c;是现代企业用于表示制程能力的指标。制程能力是过程性能的允许最大变化范围与过程的正常偏差的比值。制程能力研究在於确认这些特性符合规格的程度&#xff0c;以保证制程成品不符规格的不良率在要求的水准…

靶场练习第九天~vulnhub靶场之dc-1

一、环境搭建 靶场下载链接: 百度网盘 请输入提取码 提取码: ih67 1.查看kali的ip&#xff1a;ifconfig 二、信息收集 1.使用namp命令 主机探测: nmap -sP 192.168.101.0/24 查看靶机开放端口号和服务:nmap -A 192.168.101.111 发现开放80端口,访问一下192.168.101.111 Dru…