链接:https://ac.nowcoder.com/acm/contest/5758/B
来源:牛客网
题目描述
存在n个数,每次操作可以任选一个区间使得区间内的所有数字减一。问最少多少次操作,可以让所有数都变成1。
数据保证一定有解。
输入描述:
输入t,代表有t组数据。每组数据输入n,代表有n个数。接下来一行输入n个数,数字大小小于1e6。(t<=1000,n<1e5,∑n < 1e6)
输出描述:
每组数据输出一个整数代表最少需要操作的次数。
示例1
输入
复制
1
6
1 3 5 2 7 1
输出
复制
9
差分:
差分一般使用场景:
给出 n 个数,再给出 m 个询问,每个询问给出 l,r,x,要求你在 l 到 r 上每一个值都加上 x,而只给你 O(n) 的时间范围,怎么办?
如果暴力,时间复杂度就是 O(n^2)
如果线段树或者树状数组,时间复杂度就是 O(mlogn)
所以这里用差分,时间复杂度就是 O(n)
https://blog.csdn.net/weixin_44668898/article/details/104281102
此题明显是求区间修改的次数
#include <bits/stdc++.h>
#define ll long long
using namespace std;
//__builtin_popcount(n);
#define IOS ios::sync_with_stdio(false); cin.tie(0);cout.tie(0)
#define RI register int
const int MOD = 1e9 + 7;
const double PI = acos(-1.0);
const int INF = 0x3f3f3f3f;
const int MAXN = 2e5 + 10;
int n;
int num[MAXN];
int main()
{
int T;
scanf("%d",&T);
while(T --)
{
scanf("%d",&n);
int ans = 0;
for(int i = 1;i <= n;i ++)
{
scanf("%d",&num[i]);
ans += max(num[i - 1] - num[i],0);
}
ans += num[n] - 1;
printf("%d\n",ans);
}
return 0;
}