题目大意
有 N 个仓库,排成了一排,编号为 1~N。假设在第 i 个仓库点燃艾条,烟雾就会充满该仓库,并向左右扩散Ai的距离,接着所有|i-j|<=Ai的仓库 j 的老鼠被消灭。最少需要多少支艾条。
题解
贪心的策略
不断找右端点最靠右(),且可以和之前选过的线段相连的线段,ans++。
时间复杂度O(nlogn到n^2之间??!)
但也能过...
#include<bits/stdc++.h> using namespace std; inline int read() { int sum = 0,p = 1; char ch = getchar(); while(ch < '0' || ch > '9') { if(ch == '-') p = -1; ch = getchar(); } while(ch >= '0' && ch <= '9') { (sum *= 10) += ch - '0'; ch = getchar(); } return sum * p; } const int N = 5e5 + 5; int n,ans; struct edge { int l,r; } e[N]; int main() { freopen("cat.in","r",stdin); freopen("cat.out","w",stdout); n = read(); for(int i = 1; i <= n; i++) { int a = read(); e[i].l = max(0,i - a); e[i].r = min(n,i + a); } int far = 0,now = 1,mid; while(now <= n) { far = 0; for(int i = 1;i <= n;i++) { if(e[i].l <= now && e[i].r >= now) if(far < e[i].r) far = e[i].r; } now = far + 1; ans++; } printf("%d ",ans); return 0; }