蓝桥杯刷题--挖矿

小蓝正在数轴上挖矿,数轴上一共有 n 个矿洞,第 ii 个矿洞的坐标为 ai​ 。 小蓝从 0 出发,每次可以向左或向右移动 1 的距离,当路过一个矿洞时,就会进行挖矿作业,获得 1 单位矿石,但一个矿洞不能被多次挖掘。小蓝想知道在移动距离不超过 m 的前提下,最多能获得多少单位矿石?

输入格式

输入的第一行包含两个正整数 n,m,用一个空格分隔。

第二行包含 n 个整数 -a1​,a2​,⋯,an​,相邻整数之间使用一个空格分隔。

输出格式

输出一行包含一个整数表示答案。

样例输入

复制代码
5 4
0 -3 -1 1 2

样例输出

复制代码
4

解题思路

  1. 矿洞的坐标有正有负但是数组的下标没有负数,我们可以创建两个数组,分别存储正负的。
  2. 用前缀和减少计算量,注意前缀和数组要多开一个空间0。通过暴力枚举所有可能找最大值
cpp 复制代码
  for(int i = 1;i <= m;i++){
    int sum = r[i];//向右走i
    if(m - 2*i > 0) sum += l[m-2*i];//剩下m-2*i向左走,因为要返回

    ans = max(ans,sum);//更新答案

    sum = l[i];
    if(m - 2*i > 0) sum += r[m-2*i];
    
    ans = max(ans,sum);//更新答案
  }

3.在起点位置的矿单独计数,否则来回会加两次

cpp 复制代码
    if(!pos) f++;


    cout << ans+f << endl;//f是0处的矿数量,单独列出,如果存到前缀和数组中会加两次

完整代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

const int INF = 2e6+10;
vector<int> r(INF,0);
vector<int> l(INF,0);

int main(){
  int n,m;
  cin >> n >> m;
  int ans = 0;
  int f = 0;
  for(int i = 0;i < n;i++){
    int pos = 0;
    cin >> pos;
    if(pos > 0) r[pos] += 1;
    else l[abs(pos)] += 1;

    if(!pos) f++;
  }
  l[0] = r[0] = 0;
  for(int i = 1;i <= m;i++){
    l[i] += l[i-1];
    r[i] += r[i-1];
  }

  for(int i = 1;i <= m;i++){
    int sum = r[i];//向右走i
    if(m - 2*i > 0) sum += l[m-2*i];//剩下m-2*i向左走,因为要返回

    ans = max(ans,sum);//更新答案

    sum = l[i];
    if(m - 2*i > 0) sum += r[m-2*i];
    
    ans = max(ans,sum);//更新答案
  }

    cout << ans+f << endl;//f是0处的矿数量,单独列出,如果存到前缀和数组中会加两次

  return 0;
}
相关推荐
Navigator_Z5 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
云泽8088 小时前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法
wlsh158 小时前
Go 迭代器
算法
语戚9 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
天天进步20159 小时前
Python全栈项目实战:从零构建校园心理健康咨询平台
面试·职场和发展
CS创新实验室9 小时前
从顺序表到动态数组:数据结构的永恒基石与现代语言的优雅封装
数据结构·算法
Black蜡笔小新10 小时前
自动化AI算法训练服务器DLTM训推一体化平台助力农业生产管理实现安全智能化
人工智能·算法·自动化
武子康10 小时前
调查研究-151 Slack vs Jira:区别、使用指南与团队选择方法
人工智能·科技·深度学习·ai·职场和发展·jira·slack
8Qi811 小时前
LeetCode 23. 合并 K 个升序链表 —— 小顶堆(PriorityQueue)
数据结构·算法·leetcode·链表·
QiLinkOS11 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源