当前位置:首页 > 洛谷 > 洛谷P2381题:前缀和+双指针算法解决圆圆舞蹈

洛谷P2381题:前缀和+双指针算法解决圆圆舞蹈

6个月前 (08-12)

洛谷P2381题:前缀和+双指针算法解决圆圆舞蹈 洛谷题解 C++ 环形结构 前缀和 双指针 滑动窗口 第1张

一、题目解读

洛谷P2381题要求在一个环形轨道上,给定每个位置的距离,寻找最长的连续路径(不超过半圆周长),并计算该路径的最小距离。题目关键在于处理环形结构,并高效计算子路径距离,属于算法设计与数据结构结合的经典问题。

二、解题思路

采用“前缀和+双指针”策略:

1. 前缀和预处理:构建2N长度的数组,存储环形轨道的循环前缀和,避免环形边界判断;

2. 滑动窗口优化:双指针left/right移动,维护窗口距离不超过总距离一半,动态更新最大最小距离;

3. 边界处理:利用取模运算实现环形索引,简化代码逻辑。

三、解题步骤

1. 输入与初始化:读入N个点距离,计算总距离total;

2. 构建前缀和数组:扩展至2N长度,允许指针滑动跨越起点;

3. 双指针扫描:right递增,left动态调整(若窗口距离超限则左移),实时计算当前窗口距离;

4. 更新结果:记录所有合法窗口中的最大距离(即最小可行路径长度);

5. 输出答案:最终max_min_dist为所求结果。

四、代码与注释

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main() {
    int N;
    cin >> N;               // 读入点数
    vector<int> distances(N); // 存储各点距离
    int total = 0;
    
    // 读取输入并计算总距离
    for(int i = 0; i < N; ++i) {
        cin >> distances[i];
        total += distances[i];
    }
    
    // 构建前缀和数组(扩展2N倍)
    vector<int> prefix(2*N + 1, 0);
    for(int i = 1; i <= 2*N; ++i) {
        prefix[i] = prefix[i-1] + distances[(i-1)%N]; // 环形取模处理
    }
    
    int max_min_dist = 0;
    int left = 0;
    
    // 双指针法寻找最大最小距离
    for(int right = 0; right < 2*N; ++right) {
        int current_dist = prefix[right] - prefix[left];
        while(current_dist > total/2) { // 窗口收缩
            left++;
            current_dist = prefix[right] - prefix[left];
        }
        max_min_dist = max(max_min_dist, current_dist); // 更新答案
    }
    
    cout << max_min_dist << endl;
    return 0;
}

五、总结

该解法巧妙利用前缀和解决环形路径求和问题,双指针滑动窗口降低时间复杂度至O(N),避免暴力枚举。代码简洁且高效,适用于大规模数据场景。进一步优化方向可考虑二分查找优化窗口收缩,但当前方案已满足题目需求。


原创内容 转载请注明出处

分享给朋友:

相关文章

70.爬楼梯|三步破解动态规划核心奥秘

70.爬楼梯|三步破解动态规划核心奥秘

题意新解:站在楼梯底仰望n级台阶,每步可选1或2阶,最终的路径组合犹如斐波那契数列般展开。比如到达第3阶的路径可由第1阶跨两步,或第2阶跨一步构成,这种递推规律揭示了两两相邻状态间的紧密关联。思路解析...

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

一、题目解读力扣3112题要求解决带时间限制的最短路径问题:给定一个有向图,节点具有消失时间,需计算从起点到各节点的最短路径,且路径总时间不能超过节点的消失时间。题目难点在于需在传统最短路径算法(如D...

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

一、题目解读洛谷1184题要求处理一组地点列表与行程记录,统计其中匹配的天数。题目难点在于高效处理带有空格的字符串输入,以及快速判断每日行程是否在高手可去地点集合中。需要兼顾输入格式解析与算法效率。二...

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

一、题目解读洛谷1220题要求计算在n个位置放置灯的情况下,通过关闭连续区间灯并移动至区间端点,使得总耗电量最小。需考虑灯的功率与位置差异,设计高效的算法求解最优策略。二、解题思路1. 动态规划 +...

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

一、题目解读洛谷2652题要求对一组扑克牌进行排序,目标是找到最少需要调整的次数,使得所有牌形成同花顺。题目中,扑克牌由花色和数字组成,需先按花色排序,再在同花色内按数字排序。核心难点在于如何处理花色...

洛谷P1121题解:动态规划求解环形数组最大子段和问题(附代码注释)

洛谷P1121题解:动态规划求解环形数组最大子段和问题(附代码注释)

一、题目解读洛谷P1121题要求求解环形数组的最大子段和,即在一个环形数组中找到一个连续子段,使其元素和最大。环形数组的特殊性在于首尾元素可相连,需考虑线性子段与跨越首尾的环形子段两种情况。二、解题思...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。