Problem Description
One day, ZHJ came across a warrior novel named Kunlun in library. Soon, ZHJ fall into it.
He tells everybody how deeply he loves Kunlun no matter whom he meets.
He found it attractive so he decided to read the novel in the next N days. However, ZHJ had
his own schedule. So every day he had only few minutes to spend on the book. Besides, he was
accustomed to reading a novel continuously, that is, once he started to read the novel, he would
not stop until he had read the entire novel.
ZHJ wondered when he should begin to read the novel so that he could spend the least days
on the novel.
He tells everybody how deeply he loves Kunlun no matter whom he meets.
He found it attractive so he decided to read the novel in the next N days. However, ZHJ had
his own schedule. So every day he had only few minutes to spend on the book. Besides, he was
accustomed to reading a novel continuously, that is, once he started to read the novel, he would
not stop until he had read the entire novel.
ZHJ wondered when he should begin to read the novel so that he could spend the least days
on the novel.
Input
The input contains several cases.
The first line of each case contains two space-seperated integers N(2 <= N <= 10^5) and S(1 <= S <= 10^8) where N means ZHJ decides to finish the novel in the next N days, S means the novel would cost ZHJ S minutes.Then N lines follows.The ith line contains an integer ai(1 <= ai <= 100) which means ZHJ has ai minutes' free time in the ith day.It is guaranteed that the sum of the free time of the N days is enough for ZHJ to finish the novel.
The first line of each case contains two space-seperated integers N(2 <= N <= 10^5) and S(1 <= S <= 10^8) where N means ZHJ decides to finish the novel in the next N days, S means the novel would cost ZHJ S minutes.Then N lines follows.The ith line contains an integer ai(1 <= ai <= 100) which means ZHJ has ai minutes' free time in the ith day.It is guaranteed that the sum of the free time of the N days is enough for ZHJ to finish the novel.
Output
For each test case, you should output a single line with a integer indicating the day ZHJ should start to read the novel.If there are several answers, output the smallest one.
Sample Input
2 100 99 100 20 100 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
Sample Output
2 15
二分
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int dp[100005];
int main()
{
int n,s;
int i,j;
while(cin>>n>>s)
{
dp[0]=0;
for(i=1;i<=n;i++)
{
int x;
scanf("%d",&x);
dp[i]=dp[i-1]+x;
}
int min=1000001;
int k;
for(i=1;i<=n;i++)
{
if(dp[n]-dp[i-1]<s)
break;
else
{
int l=i,r=n;
int mid=(l+r)/2;
while(r-l>4)
{
if(dp[mid]-dp[i-1]==s)
break;
if(dp[mid]-dp[i-1]<s)
{
l=mid;
mid=(l+r)/2;
}
else
{
r=mid;
mid=(l+r)/2;
}
}
for(j=l;j<=r;j++)
if(dp[j]-dp[i-1]>=s)
{
mid=j;
break;
}
if(mid-i<min)
{
min=mid-i;
k=i;
}
}
}
cout<<k<<endl;
}
return 0;
}双边指针移动#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
int num[100006];
int i,j;
int n,s;
while(cin>>n>>s)
{
for(i=1;i<=n;i++)
scanf("%d",&num[i]);
int a=1,b=0;
int sum=0;
int min=100001;
int k;
while(b<=n&&a<=n)
{
while(sum<s&&b<n)
{
b++;
sum+=num[b];
}
if(b-a+1<min&&sum>=s)
{
min=b-a+1;
k=a;
}
sum-=num[a];
a++;
}
cout<<k<<endl;
}
return 0;
}
Kunlun小说阅读时间优化策略
本文探讨了在有限时间内高效阅读《Kunlun》小说的策略,通过分析每天可用阅读时间,确定开始阅读的最佳日子以最小化整体阅读天数。包括二分查找和双指针移动两种算法解决方案。
1636

被折叠的 条评论
为什么被折叠?



