博客
关于我
紫书 例题8-10 UVa 714 (二分答案)
阅读量:696 次
发布时间:2019-03-17

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

关于解决“数组分割问题”的二分法优化经验

在处理需要将数组分割成k个子序列,使其每个子序列的和尽可能小的问题时,可以采用二分法来高效地找到最优解。这种方法的关键在于利用了问题解的单调性,使得二分法的复杂度得以显著降低。

为什么选择二分法?有以下几点原因:

  • 单调性特性:在“子序列和尽量小”的场景下,问题的最优解呈现出明确的单调性。具体来说,当目标值越大,被分割后总和越小,因此可以借助二分查找快速缩小合适值的范围。

  • 降低复杂度:将传统的暴力枚举方法(复杂度为O(n!))转换为二分法后,复杂度能够显著降至O(n log n),这种方法在n较大时表现尤为突出。

  • 代码实现要点

    在编写二分法代码时,需要注意以下关键点:

    1. 初始值的设置

    • 左边界(l):应设置为数组元素的最小值,考虑到可能会有一些特殊情况导致最小和的爆炸性增长,所以可以将初始值设为数组元素的最大值再减一。

    • 右边界(r):设置为数组所有元素的总和,即可容纳所有可能的情况。

    2. 判断条件

    判断函数的核心逻辑是:给定一个目标值key,是否可以按照条件将数组分割成k个子序列。具体来说:

    bool judge(ll key) {    ll num = 1; // 当前分割数    ll sum = 0; // 当前累加值    for (int i = 0; i < n; i++) {        if (sum + a[i] <= key) {            sum += a[i];        } else {            num++;            sum = a[i];            if (num > k) {                return false;            }        }    }    return true;}

    这一部分的关键在于正确地处理当当前累加值超出目标值时的分割逻辑。

    3. 输出结果

    在二分法结束后,根据最终确定的结果r输出对应的数组分割结果。输出时需要注意以下几点:

  • 贪心分割:从后向前选择尽可能大的元素,这种方法可以在保证子序列和最小的前提下,尽量减少子序列的个数。

  • 分割数量控制:为了确保分割后的子序列数量正好等于k,可以使用一个变量remain来控制剩余分割的数量。

  • 结果转换:将数值结果转换为对应的分隔符表达形式,便于可读性输出。

  • 个人收获与经验总结

    在编写这段代码的过程中,我一开始并未正确设置二分法的初始边界,导致最终结果总是比预期小,从而出现了WA的情况。

    通过学习和参考刘汝佳的代码,我学会了以下几点重要技巧:

  • 边界设定:初始时左边界要设为数组元素的最大值减一,而不是随意设为0或最小值。

  • 输出逻辑:在输出时,需要严格按照分割规则从后往前选择元素,并记录各个位置的分隔标记。

  • 测试防护:在二分法结束前,应该用r--来修正边界,确保r刚好是满足条件的最大值。

  • 通过这些实践,我逐渐掌握了在解决此类二分问题时需要注意的关键点,并能够较为自信地编写出高效且正确的代码。这种问题的解决过程不仅锻炼了逻辑思维能力,也让我更加深刻地理解了二分法在算法优化中的重要价值。

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

    你可能感兴趣的文章
    NSJSON的用法(oc系统自带的解析方法)
    查看>>
    nslookup 的基本知识与命令详解
    查看>>
    NSNumber与NSInteger的区别 -bei
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NSURLSession下载和断点续传
    查看>>
    NSUserdefault读书笔记
    查看>>
    NS图绘制工具推荐
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    NT symbols are incorrect, please fix symbols
    查看>>
    ntelliJ IDEA 报错:找不到包或者找不到符号
    查看>>
    NTFS文件权限管理实战
    查看>>
    ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>
    ntp server 用法小结
    查看>>
    ntpdate 通过外网同步时间
    查看>>
    ntpdate同步配置文件调整详解
    查看>>
    NTPD使用/etc/ntp.conf配置时钟同步详解
    查看>>
    NTP及Chrony时间同步服务设置
    查看>>