cf1491C. Pekora and Trampoline
Posted Jozky86
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cf1491C. Pekora and Trampoline相关的知识,希望对你有一定的参考价值。
cf1491C. Pekora and Trampoline
题意:
有n个蹦床,每个蹦床有它的弹力值 b i b_{i} bi,从i蹦床起跳可以落到 i + b i i+b_{i} i+bi的位置上(前提是这个位置有蹦床),跳完后,蹦床的弹力值会减1,
题解:
对于一个蹦床,其弹力值为
b
i
b_{i}
bi,如果我们从这个蹦床出发,可以到达的范围其实是一个区间,会影响范围
[
i
+
1
,
i
+
b
i
]
[i+1,i+b_{i}]
[i+1,i+bi]的蹦床,使得这个范围内的蹦床弹力值-1,所以我们可以利用差分思想,对于每个蹦床,去累计对之后的影响。
如果一个蹦床受之前蹦床影响为x,x小于等于b[i]-1,就需要我们多跳b[i]-1-x下,来让b[i]减到1。
如果大于b[i]-1,说明我们会再第i个蹦床多跳y=x-(b[i]-1)下,而第i个蹦床已经减到1,因此会跳到第i+1个蹦床上,所以我们还需要积累上一次多余y
详细可以看代码
代码:
// Problem: lzh的蹦床
// Contest: NowCoder
// URL: https://ac.nowcoder.com/acm/contest/20278/A
// Memory Limit: 524288 MB
// Time Limit: 2000 ms
// By Jozky
#include <bits/stdc++.h>
#include <unordered_map>
#define debug(a, b) printf("%s = %d\\n", a, b);
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int, int> PII;
clock_t startTime, endTime;
//Fe~Jozky
const ll INF_ll= 1e18;
const int INF_int= 0x3f3f3f3f;
void read(){};
template <typename _Tp, typename... _Tps> void read(_Tp& x, _Tps&... Ar)
{
x= 0;
char c= getchar();
bool flag= 0;
while (c < '0' || c > '9')
flag|= (c == '-'), c= getchar();
while (c >= '0' && c <= '9')
x= (x << 3) + (x << 1) + (c ^ 48), c= getchar();
if (flag)
x= -x;
read(Ar...);
}
template <typename T> inline void write(T x)
{
if (x < 0) {
x= ~(x - 1);
putchar('-');
}
if (x > 9)
write(x / 10);
putchar(x % 10 + '0');
}
void rd_test()
{
#ifdef ONLINE_JUDGE
#else
startTime= clock();
freopen("data.in", "r", stdin);
#endif
}
void Time_test()
{
#ifdef ONLINE_JUDGE
#else
endTime= clock();
printf("\\nRun Time:%lfs\\n", (double)(endTime - startTime) / CLOCKS_PER_SEC);
#endif
}
#define int ll
const int maxn= 5e4 + 9;
int a[maxn];
int sum[maxn];
int d[maxn];
signed main()
{
//rd_test();
int t;
read(t);
while (t--) {
int n;
read(n);
int ans= 0;
for (int i= 1; i <= n; i++)
d[i]= 0;
for (int i= 1; i <= n; i++)
read(a[i]), ans+= a[i] - 1;
for (int i= 1; i <= n; i++) {
// if(a[i])continue;
int l= i + 2, r= min(a[i] + i, 1ll * n);
if (l > r)
continue;
d[l]++;
d[r + 1]--;
}
int last= 0;
for (int i= 1; i <= n; i++) {
d[i]+= d[i - 1];
int tmp= d[i] + last; //加上上一次操作
last= max(0ll, tmp - (a[i] - 1)); //更新本次last
ans-= min(tmp, a[i] - 1); //最小的操作
}
printf("%lld\\n", ans);
}
//Time_test();
}
以上是关于cf1491C. Pekora and Trampoline的主要内容,如果未能解决你的问题,请参考以下文章
Codeforces Global Round 13- C.Pekora and Trampoline - 贪心
1491. Average Salary Excluding the Minimum and Maximum Salary
LeetCode --- 1491. Average Salary Excluding the Minimum and Maximum Salary 解题报告
LeetCode --- 1491. Average Salary Excluding the Minimum and Maximum Salary 解题报告