【美羊羊拿金币问题】

问题:

有一天美羊羊正在草地上玩耍,突然天上开始落金币,这些金币掉落的范围在一个固定的水平区域内,但这些金币一旦掉落到地上就消失了,因此美羊羊只有不断地移动并从空中接住这些金币才能得到它们。假设金币掉落的位置为0开始到10这11个位置,美羊羊开始时站在第5个位置,它可以以每秒1个位置的速度左右移动到相邻的位置,并接住掉落的金币。请问美羊羊最多能接住多少个金币?假设它一旦接住这些金币就不会掉落到地上。

输入要求:

输入数据有多组。每组数据的第一行为一个正整数n(0<n<100000),表示有n个金币掉落在这个区域。在接下来的n行中,每行有两个整数x,t(0<t<100000),表示在第t秒有一个金币掉落在x的位置上。同一秒钟在同一位置上可能掉下多个金币。

输出要求:

每一组输入数据对应一行输出。输出一个整数m,表示美羊羊最多可能接到m个金币。

样例输入:

6

5 1

4 1

6 1

7 2

7 2

8 3

样例输出:

4

思路:

类似【拾取问题】

【拾取问题】-CSDN博客

代码:

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

#define start 5
#define length 10

int price[52][52];
int dp[52][52];
int maxt;
int dx[] = {-1, 0, 1};

void dfs(int t, int loc)
{
    if(t > maxt) return;
    int new_loc;
    for(int i = 0; i < 3; i++)
    {
        new_loc = loc + dx[i];

        if(dp[t][new_loc] < dp[t-1][loc] + price[t][new_loc]) dp[t][new_loc] = dp[t-1][loc] + price[t][new_loc];

        dfs(t+1, new_loc);
    }
}
int main()
{
    int n;
    cin >> n;

    for(int i = 1; i <= n; i++)
    {
        int loc, t;
        cin >> loc >> t;
        if(t > maxt) maxt = t;

        price[t][loc] += 1;
    }

    dfs(1, start);

    int max_price = 0;
    for(int i = 0; i <= length; i++)
    {
        if(max_price < dp[maxt][i]) max_price = dp[maxt][i];
    }

    cout << max_price << endl;

    return 0;
}
相关推荐
啊董dong几秒前
课后作业-2025年12月07号作业
数据结构·c++·算法·深度优先·noi
无限进步_21 分钟前
C语言宏的魔法:探索offsetof与位交换的奇妙世界
c语言·开发语言·windows·后端·算法·visual studio
Lucky“经营分析”29 分钟前
经营分析师-《经营分析能力》
算法
狐5731 分钟前
2025-12-04-LeetCode刷题笔记-2211-统计道路上的碰撞次数
笔记·算法·leetcode
listhi5201 小时前
激光雷达点云拟合中的ICP(迭代最近点)算法
算法
持续学习的程序员+11 小时前
强化学习阶段性总结
人工智能·算法
爱装代码的小瓶子1 小时前
【cpp知识铺子】map与set的底层AVL树
开发语言·数据结构·c++·b树·算法·链表
IT·小灰灰1 小时前
腾讯HY2.0 Think推理模型深度解析:技术突破、应用场景与实践指南
开发语言·人工智能·python·深度学习·神经网络·算法·数据分析
修炼地1 小时前
代码随想录算法训练营第二十八天 | 动态规划理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
c++·算法·动态规划
小南家的青蛙1 小时前
LeetCode第773题 - 滑动谜题
算法·leetcode·职场和发展