码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 根号分治 + 入门题目


    根号分治解决的问题有这种特点:

    1. 可以将问题按照某个界限拆分为两个子问题,通常界限设为 n \sqrt n n ​
    2. 对于拆分出来的两个子问题,一部分可以暴力求解,另一部分可以使用算法求解。这样分治的话,可以使得两个子问题的时间复杂度刚好都是 n ⋅ n n\cdot \sqrt n n⋅n ​ ,得以解决问题

    题目:


    E. Array Queries

    题意:

    • 给定长度为 n n n 的序列 a a a。 m m m 次询问。
    • 每次询问给出 p , k p,k p,k。您要不断地执行操作 p ← p + a p + k p\gets p+a_p+k p←p+ap​+k,直到 p > n p>n p>n 为止。询问的答案为操作次数。
    • 1 ≤ n , q ≤ 1 0 5 1\le n,q\le 10^5 1≤n,q≤105, 1 ≤ a i ≤ n 1\le a_i\le n 1≤ai​≤n, 1 ≤ p , k ≤ n 1\le p,k\le n 1≤p,k≤n。

    思路:

    对于 k > n k> \sqrt n k>n ​ 的询问,暴力即可,枚举的次数不超过 n \sqrt n n ​ 。

    对于 k ≤ n k\leq \sqrt n k≤n ​ 的询问,可以预处理 ( p , k ) (p,k) (p,k) 状态需要跳的步数,时空复杂度 O ( n ⋅ n ) O(n\cdot \sqrt n) O(n⋅n ​) 。

    AC代码:https://codeforces.com/contest/797/submission/182309787


    D1. Frequency Problem (Easy Version)

    题意:

    给定 a 1 , a 2 , . . . , a n a_1,a_2,...,a_n a1​,a2​,...,an​,求最长的满足区间众数有至少两种的区间长度。如果不存在这样的区间,输出 0 0 0。

    n ≤ 2 × 1 0 5 , 1 ≤ a i ≤ min ⁡ ( 100 , n ) n\leq 2\times 10^5,1\leq a_i\leq \min(100,n) n≤2×105,1≤ai​≤min(100,n)

    思路:略。详见 题解 。

    AC代码:https://codeforces.com/contest/1446/submission/182314629


    D2. Frequency Problem (Hard Version)

    题意:将上一题的 1 ≤ a i ≤ min ⁡ ( 100 , n ) 1\leq a_i\leq \min(100,n) 1≤ai​≤min(100,n) 改为 1 ≤ a i ≤ n 1\leq a_i\leq n 1≤ai​≤n 。

    题解:题解 CF1446D1 【Frequency Problem (Easy Version)】

    思路:

    对于 a i > n a_i> \sqrt n ai​>n ​ 的数字,最多有 n \sqrt n n ​ 种,按照 easy.ver 的思路即可。

    对于 a i ≤ n a_i\leq \sqrt n ai​≤n ​ 的数字,枚举出现次数上界,然后双指针找最长子区间。

    AC代码:https://codeforces.com/contest/1446/submission/182317190

  • 相关阅读:
    vue2 elementui 封装一个动态表单复杂组件
    什么是数据库锁(Lock)?有哪些类型的锁
    谷歌爬虫插件webscraper使用详细实操
    Axure8.0教程:自动带出邮箱
    dflow入门5——Big step & Big parameter
    UCloud 对象存储使用
    除了Excel中可以添加公式之外,在Word中也可以添加公式,不过都是基于表格
    07.docker容器的网络访问
    GPT接入企微应用 - 让工作快乐起来
    OA项目之我的审批(查询&会议签字)
  • 原文地址:https://blog.csdn.net/weixin_51948235/article/details/128017696
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号