scau 10692 XYM-入门之道
发布时间:2022-10-30 14:05:20 344 相关标签: # ubuntu
题目:http://paste.ubuntu.com/14157516/
思路:判断一个西瓜,看看能不能直接吃完,如果能,就吃了。但是:如果不能,就要分成两半,就这样分割,不用以为要用到n维数组,用一个一维数组就够了,利用队列的特点,把分割了的入队,然后一直遍历整个队列。
#include
#include
void work()
{
int n,k;
int que[100000]={0};
int head,tail;
int i_count=0;
head=tail=1;
scanf ("%d%d",&n,&k);
que[tail++]=n;
while (head {
if (que[head]<=k)
{
i_count++;
head++;
}
else
{
if (que[head]%2==0)
{
que[tail++]=que[head]/2;
que[tail++]=que[head]/2;
head++;
}
else
{
que[tail++]=que[head]/2;
que[tail++]=que[head]/2+1;
head++;
}
}
}
printf ("%d\n",i_count);
return ;
}
int main()
{
int t;
scanf ("%d",&t);
while (t--)
{
work();
}
return 0;
}
文章来源: https://blog.51cto.com/u_15833059/5779288
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报