【笔试】算法的暴力美学——牛客 NC221681:dd爱框框

一、题目描述

二、算法原理

思路:滑动窗口

1)定义两个指针,一开始都为0,cur 从左开始遍历,定义一个 sum 来表示 prev 到 cur 的之间的值的总和,当 sum >= x 时,我们要根据题目条件来保存 prev 和 cur 的值;

2)当 sum >= x 时,我们记录完 prev 和 cur 的值的之后,sum -= arr prev ,prev++ ,往后走,只要满足条件 sum >= x 我们就要记录 prev 和 cur 的值,不断重复上面的工作;

3)当 sum < x 时,cur++,sum += arr cur

4)直至遍历完整个数组;

三、代码实现

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

int main()
{
    //准备工作
    int n,x;
    cin >> n >> x;
    vector<int> arr(n,0);
    
    for(int i = 0; i < n; i++) cin >> arr[i];
    int index[2] = {0};//保存最后的结果
    
    //滑动窗口
    int cur = 0;
    int prev = 0;
    int sum = 0;
    while(cur < n)
    {
        sum += arr[cur];
        while(sum >= x)//入窗口
        {
            if(index[0] == 0 && index[1] == 0)
            {
                index[0] = prev;
                index[1] = cur;
                sum -= arr[prev++];
                continue;
            }
            int length = index[1] - index[0];
            int camplen = cur - prev;
            if(length == camplen || length > camplen)
            {
                if(prev < index[0] || length > camplen)
                {
                    index[0] = prev;
                    index[1] = cur;
                }
            }
            sum -= arr[prev++];
        }
        //出窗口
        cur++;
    }
    
    cout << index[0] + 1 << ' ' << index[1] + 1 << endl;
    
    return 0;
}
相关推荐
烬羽1 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说17 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰20 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术21 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考2 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队2 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法