其实这两个题都是一样的思路,一个正着变,一个反着变。所以可以从前的到后遍历数组,如果a[i] > a[i - 1],就加上他们之间的差值,如果a[i] <= a[i - 1],a[i]可以借助a[i - 1]来实现,也就是不用单独再多出来次数了【贪心】。如果看差分的话,即答案为把差分数组所有正数加起来的和。
积木大赛
原题链接:登录—专业IT笔试面试备考平台_牛客网
AC代码:
#include<bits/stdc++.h>
#define INF 0x3f3f3f3f
#define ll long long
#define PII pair<int,int>
#define rep(i, n) for (int i = 1; i <= (n); ++i)
#define rrep(i, n) for(int i = n; i >= 1; ++i)
using namespace std;
const double pi = acos(-1.0);
const int N = 1e5 + 10;
int a[N], b[N];
int main()
{
int n;
scanf("%d", &n);
int res = 0;
rep(i, n) scanf("%d", &a[i]), b[i] = a[i] - a[i - 1];
for(int i = 1; i <= n; i++)
if(a[i] > a[i - 1]) res += a[i] - a[i - 1];
cout << res;
return 0;
}
道路铺设
AC代码:
一样的思路,可以自己写一下~