码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法设计与分析-8593 最大覆盖问题


    输入样例

    10
    1 6 2 1 -2 3 5 2 -4 3
    

    输出样例

    5

    感谢 向晚大魔王Avvvvvva   同学在评论中指出文章一些错误。

    网上一些题解都是错的......

    题解一:最大覆盖问题算法设计 - 豆丁网

     10
    -10 6 2 1 -2 3 5 2 -6 9

    答案是10,因为9比前面任何一个数都大,这和绝对值递增并无关系。

    题解二:我的思路是dp。dp[i]表示以第i个为结尾的最大覆盖长度。然后枚举第i + 1个时,如果其abs还比a[i]小,那么dp[i + 1] = 1,就是自己一个了。
    否则,因为它比a[i]大了,而a[i]之前也算好了dp[i],就是[i - dp[i] + 1, dp[i] ]这段区间是比abs(a[i])小的了,所以可以不比较这段区间,直接和i - dp[i]比较即可。然后递归下去。

    错误点:a[i]

    例如

    5
    6 3 4 -5 1
    当计算到1时,注意1的绝对值比-5大,但是你不能继承-5覆盖的区间。

    OJ上此题目可用暴力枚举的方法通过,枚举j元素左边有多少个满足条件元素,这是O(n^2)平方级算法:

    1. #include <iostream>
    2. using namespace std;
    3. int main()
    4. {
    5. int i,j,n,maxc=1,a[10001];
    6. cin>>n;
    7. for(i=1;i<=n;i++)
    8. cin>>a[i];
    9. for(j=n;j>1;j--)
    10. {
    11. if(a[j]<0) /**< 取绝对值,因为从后往前比对,所以改变a[j]不会影响运算结果 */
    12. a[j]=-a[j];
    13. for(i=j;i>=1;i--)/**< 找到第一个不满足条件a[i] */
    14. if(a[i]>a[j])
    15. break;
    16. maxc=max(maxc,j-i);/**< j-i覆盖区间长度 */
    17. }
    18. cout<<maxc;
    19. return 0;
    20. }

    OJ题解:双指针法


    初始时,用两个指针i和j指向串末,当ai和aj的关系满足不等式时,j不动,i往左
    走,……,直到不等式不满足,记录下长度。
    下一步j往左移一个,i不回退,继续上面的比较,若找到更长的覆盖长度,更新。
    每循环一次要么i要么j少1;最后i=-1,j=0;共进行了2(n-1)次。所以时间复杂度为O(n)。

    1. #include <iostream>
    2. using namespace std;
    3. int abs(int n)
    4. {
    5. return n>=0?n:-n;
    6. }
    7. int main()
    8. {
    9. int i,j,n,maxc=1,a[10001];
    10. cin>>n;
    11. for(i=1;i<=n;i++)
    12. cin>>a[i];
    13. j=n,i=n;
    14. while(i>=1)
    15. {
    16. if(abs(a[j])>=a[i]) /**< 满足条件,继续试探,同时检查最长覆盖 */
    17. maxc=max(maxc,j-i+1),i--;
    18. else /**< 不满足条件,看看a[j-1]能否继续前行,当然只有abs(a[j-1])>abs(a[j])时才能继续前行 */
    19. j--;
    20. }
    21. cout<<maxc;
    22. return 0;
    23. }

  • 相关阅读:
    【数字信号调制】16QAM信号调制解调【含Matlab源码 2050期】
    JDK、eclipse软件的安装
    Flutter异步与线程详解
    想理解Java的IO,不要从操作系统开始说起的都是耍流氓
    [兔子私房课] Mybatis开发详解与项目实战02
    【触想智能】工业触摸显示器在户外使用需要注意哪些问题?
    Swift中和C语言数据类型转换
    蚂蚁二面,面试官问我零拷贝的实现原理,当场懵了…
    Leetcode第150题—逆波兰表达式
    好莱坞罢工事件!再次警醒人类重视AI监管,人工智能矛盾一触即发!
  • 原文地址:https://blog.csdn.net/sigd/article/details/126862515
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号