码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • E. Block Sequence Codeforces Round 903 (Div. 3)


    Problem - E - Codeforces

    题目大意:有一个长为n的数组a,对于一个子串b如果b[1]=子串长度+1,则称这个子串合法,现每次操作可以移除一个a[i],问最少几次操作可以将a分割成多个不重合的合法子串

    1<=n<=2e5;1<=a[i]<=1e6

    思路:设dp[i]为所有小于等于i的位置都已合法,那么如果要要删除a[i],dp[i]就应该等于dp[i+1]+1,如果不删除且它是一个合法子串的第一个数,那么dp[i]就等于dp[i+a[i]+1]+1,如果是合法子串中其他位置的数就是dp[i],我们从后往前遍历,三种情况取最小即可

    1. //#include<__msvc_all_public_headers.hpp>
    2. #include
    3. using namespace std;
    4. typedef long long ll;
    5. const int N = 2e5 + 5;
    6. vectorint,int>>fac;
    7. int tot = 0;
    8. int n;
    9. int dp[N];
    10. int a[N];
    11. void init()
    12. {
    13. for (int i = 1; i <= n; i++)
    14. {
    15. dp[i] = 0x7fffffff;//初始化为最大值
    16. }
    17. dp[n + 1] = 0;//初始化边界值
    18. }
    19. void solve()
    20. {
    21. int m;
    22. cin >> n;
    23. init();
    24. for (int i = 1; i <= n; i++)
    25. {
    26. cin >> a[i];
    27. }
    28. for (int i = n; i >= 1; i--)
    29. {//从后往前遍历
    30. dp[i] = min(dp[i], dp[i + 1] + 1);//删除这个数
    31. if (i + a[i] <= n)
    32. {
    33. dp[i] = min(dp[i], dp[i + a[i]+1]);//合法区间额度第一个数
    34. }
    35. }
    36. cout << dp[1];//答案
    37. cout <<'\n';
    38. }
    39. int main()
    40. {
    41. std::ios::sync_with_stdio(false);
    42. std::cin.tie(0);
    43. //FILE* stream1;
    44. //freopen_s(&stream1, "in.txt", "r", stdin);
    45. //freopen_s(&stream1, "out.txt", "w", stdout);
    46. int t;
    47. cin >> t;
    48. while (t--)
    49. {
    50. solve();
    51. }
    52. return 0;
    53. }

  • 相关阅读:
    【JVM】第四篇 垃圾收集器ParNew&CMS底层三色标记算法详解
    让你快速理解工厂模式
    .Net开发——EFCore
    TOYOTA MOTOR CORPORATION Programming Contest 2022(AtCoder Beginner Contest 270)
    进程与线程的相爱相杀
    14:00面试,14:06就出来了,问的问题有点变态。。。
    bp神经网络中的重要函数解释
    Java数据结构——第八节-二叉树(全)(2.1万字)
    【vue】vue2.x解决兼容IE8以上问题:
    第15章_锁: MySQL并发访问相同记录以及从数据操作的类型划分锁(读锁、写锁)
  • 原文地址:https://blog.csdn.net/ashbringer233/article/details/133880356
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号