博客
关于我
[bzoj3203][三分]保护出题人
阅读量:95 次
发布时间:2019-02-26

本文共 1978 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要找到每一关植物攻击力的最小总和。我们可以通过数学建模和单调栈的方法来高效解决这个问题。

方法思路

  • 问题分析:每一关有多个僵尸,每个僵尸的血量和位置不同。我们需要计算每一关的植物攻击力,最终求所有关的攻击力总和的最小值。
  • 数学建模:每一关的植物攻击力可以看作是点集中的最大斜率。通过前缀和数组,我们可以将问题转化为找出最大斜率的问题。
  • 单调栈:使用单调栈来维护下凸包,确保每次加入新点时,栈中的点集是下凸的。这样,我们只需要在栈顶中查找最大斜率即可。
  • 解决代码

    #include 
    #include
    #include
    #include
    #include
    using namespace std;struct pt { double x, y;};double slope(const pt &u, const pt &v) { return (v.y - u.y) / (v.x - u.x);}double main() { int n, D; scanf("%d %d", &n, &D); double *s = new double[n + 1]; for (int i = 1; i <= n; ++i) { double A, X; scanf("%lf %lf", &A, &X); s[i] = s[i - 1] + A; } pt *sta = new pt[2 * n]; int top = 0; for (int T = 1; T <= n; ++T) { double A, X; scanf("%lf %lf", &A, &X); sta[top].x = D * T; sta[top].y = s[T - 1]; while (top > 0 && slope(sta[top - 1], sta[top]) >= slope(sta[top], sta[top + 1])) { top--; } sta[top + 1].x = X + D * T; sta[top + 1].y = s[T]; int l = 1, r = top; while (r - l > 3) { int mid = (l + r) / 2; int mmid = mid + 1; if (slope(sta[mid], sta[top + 1]) > slope(sta[mmid], sta[top + 1])) { l = mid; } else { r = mmid - 1; } } int op = l; for (int i = l + 1; i <= r; ++i) { if (slope(sta[i], sta[top + 1]) > slope(sta[op], sta[top + 1])) { op = i; } } if (op != l) { ans += slope(sta[op], sta[top + 1]); } else { ans += 0; } } printf("%.0lf\n", round(ans)); delete[] sta; delete[] s; return 0;}

    代码解释

  • 输入处理:读取输入数据,包括关数n和距离d,然后读取每一关的血量和位置。
  • 前缀和数组:计算前缀和数组s,用于后续斜率计算。
  • 下凸包维护:使用单调栈维护下凸包,确保每次加入新点时,栈中的点集是凸的。
  • 斜率计算:计算每一关的最大斜率,并累加到总和中。
  • 输出结果:输出最小总和,保留到整数部分。
  • 这种方法通过数学建模和单调栈优化,有效地将问题复杂度降低,确保了在较大数据量下的高效计算。

    转载地址:http://tsmu.baihongyu.com/

    你可能感兴趣的文章
    Netty+Protostuff实现单机压测秒级接收35万个对象实践经验分享
    查看>>
    Netty+SpringBoot+FastDFS+Html5实现聊天App详解(一)
    查看>>
    netty--helloword程序
    查看>>
    netty2---服务端和客户端
    查看>>
    【Flink】Flink 2023 Flink易用性和稳定性在Shopee的优化-视频笔记
    查看>>
    Netty5.x 和3.x、4.x的区别及注意事项(官方翻译)
    查看>>
    netty——bytebuf的创建、内存分配与池化、组成、扩容规则、写入读取、内存回收、零拷贝
    查看>>
    netty——Channl的常用方法、ChannelFuture、CloseFuture
    查看>>
    netty——EventLoop概念、处理普通任务定时任务、处理io事件、EventLoopGroup
    查看>>
    netty——Future和Promise的使用 线程间的通信
    查看>>
    netty——Handler和pipeline
    查看>>
    Vue输出HTML
    查看>>
    netty——黏包半包的解决方案、滑动窗口的概念
    查看>>
    Netty中Http客户端、服务端的编解码器
    查看>>
    Netty中使用WebSocket实现服务端与客户端的长连接通信发送消息
    查看>>
    Netty中实现多客户端连接与通信-以实现聊天室群聊功能为例(附代码下载)
    查看>>
    Netty中的组件是怎么交互的?
    查看>>
    Netty中集成Protobuf实现Java对象数据传递
    查看>>
    netty之 定长数据流处理数据粘包问题
    查看>>
    Netty事件注册机制深入解析
    查看>>