题目大意:给定一些牛,每头牛有一个初始位置和速度,如果某头牛能追上后面的那头速度就会和后面那头一样,求T分钟后会形成多少小团体
《论排序算法的低效性和如何避免使用排序算法以及认真读题的重要性》
一头牛的速度不会被后面的牛所影响
因此我们从后往前扫,如果当前的牛追不上后面那个小团体中最慢的那头牛,这头牛就成为新的小团体
时间复杂度O(n)
注意数据有点问题,虽然说初始位置和速度都小于等于100W但是实际上有比这个大的
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define M 100100 using namespace std; int n,ans,pos[M],spd[M]; long long T; int main() { int i; cin>>n>>T; for(i=1;i<=n;i++) scanf("%d%d",&pos[i],&spd[i]); pos[n+1]=spd[n+1]=2147483647; int slowest=n+1; for(i=n;i;i--) { if(pos[i]+spd[i]*T<pos[slowest]+spd[slowest]*T) ++ans,slowest=i; } cout<<ans<<endl; return 0; }
BZOJ 3893 [Usaco2014 Dec]Cow Jog
原文地址:http://blog.csdn.net/popoqqq/article/details/43971895