Dust_Settled @ 2022-10-19 22:38:14
#include<bits/stdc++.h>
using namespace std;
int n,a[5001],start[6],end_[6],z,f,m;
bool pd_run(int s){
if(!s%100)
if(!s%400) return 1;
else
if(!s%4) return 1;
return 0;
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
scanf("%d-%d-%d-%d:%d",&start[1],&start[2],&start[3],&start[4],&start[5]);
scanf("%d-%d-%d-%d:%d",&end_[1],&end_[2],&end_[3],&end_[4],&end_[5]);
for(int i=start[1];i<end_[1];i++)
if(pd_run(i)) z+=366;
else z+=365;
for(int i=1;i<start[2];i++)
if(i==1||i==3||i==5||i==7||i==8||i==10||i==12) z-=31;
else if(i==2)
if(pd_run(start[1])) z-=29;
else z-=28;
else z-=30;
for(int i=1;i<end_[2];i++)
if(i==1||i==3||i==5||i==7||i==8||i==10||i==12) z+=31;
else if(i==2)
if(pd_run(end_[1])) z+=29;
else z+=28;
else z+=30;
z=z-start[3]+end_[3];
z=z*1440+end_[4]*60+end_[5]-start[4]*60-start[5];
sort(a+1,a+n+1);
for(int i=1;i<=n;i++)
if(z>=a[i]) z-=a[i],m++;
else break;
printf("%d\n",m);
return 0;
}