码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • River Locks


     

     

    传送门

    题意:

    n个船闸,每个有体积为v, 每个船闸都有一个水管,水管每秒可以放1单位的水,当第i个船闸的水满时,会向i + 1船闸转移,转移的时间为0,有q次询问,每次询问一个时间t, 问在时间t下需要的最少的水管数使所有的船闸都装满水,不行的输出 -1

    思路:

    首先,贪心要选水管肯定是前面的优先,考虑前i个船闸装满水需要的最少时间,dp[i], 二分求得,最后询问,只要t >= dp[n] && count <= n就是可以的, count == (sum[n] + t - 1) / t(向上取整)

    1. #include
    2. #define endl '\n'
    3. #define IOS ios::sync_with_stdio(false);
    4. using namespace std;
    5. typedef long long ll;
    6. const int N = 2e5 + 10;
    7. ll n, t, q;
    8. ll v[N], dp[N]; //dp[i]代表将前i个船闸填满水需要的最少时间
    9. ll sum[N];
    10. int main()
    11. {
    12. IOS; cin.tie(0), cout.tie(0);
    13. cin >> n;
    14. for (int i = 1; i <= n; ++i)
    15. {
    16. cin >> v[i];
    17. }
    18. dp[1] = v[1], sum[1] = v[1];
    19. for (int i = 2; i <= n; ++i)
    20. {
    21. sum[i] = sum[i - 1] + v[i];
    22. ll l = dp[i - 1], r = 1e9, mid, ans = 1e9; //因为第i个填满需要的最少时间肯定是在前i - 1个转移过来的,所以l = dp[i - 1]
    23. while (l <= r)
    24. {
    25. mid = (l + r) >> 1;
    26. if (mid * i - sum[i - 1] >= v[i])
    27. {
    28. ans = min(ans, mid);
    29. r = mid - 1;
    30. }
    31. else
    32. l = mid + 1;
    33. }
    34. dp[i] = ans;
    35. }
    36. cin >> q;
    37. while (q--)
    38. {
    39. cin >> t;
    40. //需要的时间肯定要大于dp[n], 再次基础上sum[n] / t, 向上取整就是需要的最少水管数
    41. int count = (sum[n] + t - 1) / t;
    42. if (dp[n] <= t && count <= n)
    43. cout << count << endl;
    44. else
    45. cout << "-1" << endl;
    46. }
    47. return 0;
    48. }

  • 相关阅读:
    Rust实战系列-基本语法
    uniapp实现安卓端导出execl、打包excel为zip压缩文件、分享zip压缩文件到微信、qq
    Java 24 Design Pattern 之 工厂模式
    Ollama:本地部署大模型 + LobeChat:聊天界面 = 自己的ChatGPT
    从零学算法(LCR 135)
    解决jenkins流水线报错did not complete successfully: exit code: 127
    【FISCO BCOS】十九、区块链浏览器部署
    考研数据结构与算法(五)数组
    基于ZLMediaKit的GB28181视频平台demo
    less 里面的calc 和 运算符有什么区别 ?
  • 原文地址:https://blog.csdn.net/qq_63010655/article/details/125890597
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号