机器人跳跃问题

机器人正在玩一个古老的基于 DOS 的游戏。

游戏中有 N+1N+1 座建筑------从 00 到 NN 编号,从左到右排列。

编号为 00 的建筑高度为 00 个单位,编号为 ii 的建筑高度为 H(i)H(i) 个单位。

起初,机器人在编号为 00 的建筑处。

每一步,它跳到下一个(右边)建筑。

假设机器人在第 kk 个建筑,且它现在的能量值是 EE,下一步它将跳到第 k+1k+1 个建筑。

如果 H(k+1)>EH(k+1)>E,那么机器人就失去 H(k+1)−EH(k+1)−E 的能量值,否则它将得到 E−H(k+1)E−H(k+1) 的能量值。

游戏目标是到达第 NN 个建筑,在这个过程中能量值不能为负数个单位。

现在的问题是机器人至少以多少能量值开始游戏,才可以保证成功完成游戏?

输入格式

第一行输入整数 NN。

第二行是 NN 个空格分隔的整数,H(1),H(2),...,H(N)H(1),H(2),...,H(N) 代表建筑物的高度。

输出格式

输出一个整数,表示所需的最少单位的初始能量值上取整后的结果。

数据范围

1≤N,H(i)≤1051≤N,H(i)≤105,

输入样例1:
复制代码
5
3 4 3 2 4
输出样例1:
复制代码
4
输入样例2:
复制代码
3
4 4 4
输出样例2:
复制代码
4
输入样例3:
复制代码
3
1 6 4
输出样例3:
复制代码
3

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 难度:中等 |
| 时/空限制:3s / 64MB |
| 总通过数:25556 |
| 总尝试数:58468 |
| 来源: 今日头条2019笔试题 |
| 算法标签 |

cpp 复制代码
#include <iostream>

using namespace std ;
#define int unsigned long long
const int N = 1e5+10;
int a[N];
int n;
bool check(int t)
{
    for(int j = 0; j < n; j++)
        {
            // cout << t << endl;
            if(t >= a[j])
                t += (t - a[j]);
            if(t < a[j])
                t -= (a[j] - t);
            // cout << t << endl;
            if(t < 0)  
            {
                
                return false;
            }
            // if (t >= 1e5) return true;
               
        }
      return true;
} 
signed main()
{
    
    cin >> n;
    
    for(int i = 0; i < n; i++)  cin >> a[i];
    int l = 1, r = 1e5+ 10;
    while(l < r)
    {
        int mid = (l + r) >> 1;
        if(check(mid))  r = mid;
        else l = mid + 1;
    }
    cout << l << endl;
}

递推

cpp 复制代码
//递推解方程
#include<bits/stdc++.h>

using namespace std;

const int N = 1e5 + 10;

int n;
int h[N];
double p[N];//存放2的次幂

int main()
{
    cin >> n;
    for(int i = 1; i <= n; i++) cin >> h[i];

    p[0] = 1;//2^0=1

    double res = 0;
    for(int i = 1; i <= n; i++)
    {
        p[i] = p[i - 1] * 2;
        res += 1.0 / p[i] * h[i];
    }

    cout << ceil(res) << endl;

    return 0;
}
相关推荐
Salt_07287 分钟前
DAY44 简单 CNN
python·深度学习·神经网络·算法·机器学习·计算机视觉·cnn
货拉拉技术8 分钟前
AI拍货选车,开启拉货新体验
算法
MobotStone25 分钟前
一夜蒸发1000亿美元后,Google用什么夺回AI王座
算法
Wang2012201329 分钟前
RNN和LSTM对比
人工智能·算法·架构
xueyongfu33 分钟前
从Diffusion到VLA pi0(π0)
人工智能·算法·stable diffusion
永远睡不够的入43 分钟前
快排(非递归)和归并的实现
数据结构·算法·深度优先
cheems952744 分钟前
二叉树深搜算法练习(一)
数据结构·算法
sin_hielo1 小时前
leetcode 3074
数据结构·算法·leetcode
Yzzz-F1 小时前
算法竞赛进阶指南 动态规划 背包
算法·动态规划
程序员-King.1 小时前
day124—二分查找—最小化数组中的最大值(LeetCode-2439)
算法·leetcode·二分查找