热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

hdu1823LuckandLove(线段树)

版权声明:本文为博主原创文章。未经博主同意不得转载。https:blog.csdn.netSCNU_Jiechaoarticledetails24406391题意&#
版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.csdn.net/SCNU_Jiechao/article/details/24406391

题意:Wiskey招女友,每一个女生看其身高、活泼度和缘分值。如今运行两种操作,1、I。增加一位女生的身高。活泼度和缘分值;2、Q,查询身高在H1, H2之间,活泼度在A1, A2之间的女生的最高缘分值。

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1823

——>>查询某个区间的最值,若是一维,可用RMQ解法。。也可用线段树解法。。

如今要查身高限一个区间。活泼度限一个区间,是一个二维的情景。

。将线段树扩至二维。。时间复杂度:O(N+M*log(N)^2)。。

——>>坑1:G++的BUG。。大哭

。以G++提交数次皆WA。

改交C++即过。。有朋友指出是代码触发了没有定义行为,也有朋友说是由于G++的O2 BUG。

——>>坑2:题目中说是1位小数。那么。处理方法用scanf("%d.%d", &A1, &A2)。再进行A1 * 10 + A2,会比用scanf("%lf", &A),再进行(int)(A * 10)更精确(自己測下0.0到0.9就能够发现)。。但是,用第一种处理方式却会WA,偏偏要用另外一种不那么精确的处理方式才会AC。。大哭

第一道二维线段树题目,做到想哭了。

#include
#include using namespace std;#define lc (o<<1)
#define rc ((o<<1)|1)const int maxh &#61; 100 &#43; 10;
const int maxa &#61; 1000 &#43; 10;
int mmax[maxh<<2][maxa<<2];void build_A(int O, int o, int L, int R) { //活泼度建树mmax[O][o] &#61; -1;if(L &#61;&#61; R) return;int M &#61; (L &#43; R) >> 1;build_A(O, lc, L, M);build_A(O, rc, M&#43;1, R);
}void build_H(int o, int L, int R) { //身高建树build_A(o, 1, 0, 1000);if(L &#61;&#61; R) return;int M &#61; (L &#43; R) >> 1;build_H(lc, L, M);build_H(rc, M&#43;1, R);
}void Insert_A(int O, int o, int L, int R, int A, int D) { //依据活泼度建树if(L &#61;&#61; R) {mmax[O][o] &#61; max(mmax[O][o], D);return;}int M &#61; (L &#43; R) >> 1;if(A <&#61; M) Insert_A(O, lc, L, M, A, D);else Insert_A(O, rc, M&#43;1, R, A, D);mmax[O][o] &#61; max(mmax[O][lc], mmax[O][rc]);
}void Insert(int o, int L, int R, int H, int A, int D) {Insert_A(o, 1, 0, 1000, A, D);if(L &#61;&#61; R) return;int M &#61; (L &#43; R) >> 1;if(H <&#61; M) Insert(lc, L, M, H, A, D);else Insert(rc, M&#43;1, R, H, A, D);
}int query_A(int O, int o, int L, int R, int A1, int A2) { //依据活泼度查询if(A1 <&#61; L && R <&#61; A2) return mmax[O][o];int M &#61; (L &#43; R) >> 1;int Max1 &#61; -1, Max2 &#61; -1;if(A1 <&#61; M) Max1 &#61; query_A(O, lc, L, M, A1, A2);if(A2 > M) Max2 &#61; query_A(O, rc, M&#43;1, R, A1, A2);return (Max1 > Max2) ? Max1 : Max2;
}int query(int o, int L, int R, int H1, int H2, int A1, int A2) {if(H1 <&#61; L && R <&#61; H2) return query_A(o, 1, 0, 1000, A1, A2);int M &#61; (L &#43; R) >> 1;int Max1 &#61; -1, Max2 &#61; -1;if(H1 <&#61; M) Max1 &#61; query(lc, L, M, H1, H2, A1, A2);if(H2 > M) Max2 &#61; query(rc, M&#43;1, R, H1, H2, A1, A2);return (Max1 > Max2) ?

Max1 : Max2; } int main() { int M; char op; while(scanf("%d", &M) &#61;&#61; 1 && M) { build_H(1, 100, 200); for(int i &#61; 0; i A2) swap(A1, A2); if(H1 > H2) swap(H1, H2); // if(A[0] > A[1]) swap(A[0], A[1]); // int ret &#61; query(1, 100, 200, H1, H2, A[0], A[1]); int ret &#61; query(1, 100, 200, H1, H2, A1, A2); ret !&#61; -1 ?

printf("%.1f\n", ret/10.0) : puts("-1"); } } } return 0; }




转:https://www.cnblogs.com/xfgnongmin/p/10619015.html



推荐阅读
  • 本文详细介绍了Linux内核中misc设备驱动框架的实现原理及应用方法,包括misc设备的基本概念、驱动框架的初始化过程、数据结构分析以及设备的注册与注销流程。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 优化后的摘要:本文详细分析了当前面临的挑战和机遇,结合具体实例探讨了如何通过创新和改革来推动长期可持续发展。文中还介绍了多种可行的解决方案,并强调了在不同阶段实施这些方案的重要性。 ... [详细]
  • 本文深入探讨了UNIX/Linux系统中的进程间通信(IPC)机制,包括消息传递、同步和共享内存等。详细介绍了管道(Pipe)、有名管道(FIFO)、Posix和System V消息队列、互斥锁与条件变量、读写锁、信号量以及共享内存的使用方法和应用场景。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • This guide provides a comprehensive step-by-step approach to successfully installing the MongoDB PHP driver on XAMPP for macOS, ensuring a smooth and efficient setup process. ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 深入解析 Android IPC 中的 Messenger 机制
    本文详细介绍了 Android 中基于消息传递的进程间通信(IPC)机制——Messenger。通过实例和源码分析,帮助开发者更好地理解和使用这一高效的通信工具。 ... [详细]
  • docker镜像重启_docker怎么启动镜像dock ... [详细]
author-avatar
ANANREMEMBERO38_810
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有