杭电1250,求bug...

#include<stdio.h>#defineN10000000000inthead[4];__int64number[4][210];voidadd(intn){in... #include<stdio.h>
#define N 10000000000
int head[4];
__int64 number[4][210];

void add(int n)
{
int i,m;
for(i = 0,m = 210;i < 4;i ++)
if(m > head[i])
m = head[i];
for(i = 209;i >= m;i --)
{
number[n%4][i] += number[(n+1)%4][i] + number[(n+2)%4][i] + number[(n+3)%4][i];
if(number[n%4][i] >= N)
{
head[n%4] = i - 1;
number[n%4][i - 1] += number[n%4][i] / N;
number[n%4][i] %= N;
}
else
head[n%4] = i;
}

}

int main(){
int n,i,j;
while(scanf("%d",&n) != EOF)
{
for(i = 0;i < 4;i ++)
for(j = head[i];j < 210;j ++)
number[i][j] = 0;
for(i = 0;i < 4;i ++)
{
head[i] = 209;
number[i][head[i]] = 1;
}
for(i = 5;i <= n;i ++)
add(i);
for(j = head[n%4];j <= 209;j ++)
{
if(number[n%4][j] == 0)
printf("0000000000");
else
printf("%I64d",number[n%4][j]);
}
printf("\n");
}
return 0;
}
展开
 我来答
porker2008
2012-06-17 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
#include<stdio.h>
#define N 10000000000LL
int head[4];
__int64 number[4][210];

void add(int n)
{
int i,m;
for(i = 0,m = 210;i < 4;i ++)
if(m > head[i])
m = head[i];
for(i = 209;i >= m;i --)
{
number[n%4][i] += number[(n+1)%4][i] + number[(n+2)%4][i] + number[(n+3)%4][i];
if(number[n%4][i] >= N)
{
head[n%4] = i - 1;
number[n%4][i - 1] += number[n%4][i] / N;
number[n%4][i] %= N;
}
else
head[n%4] = i;
}

}

int main(){
int n,i,j;
char buffer[100];
while(scanf("%d",&n) != EOF)
{
for(i = 0;i < 4;i ++)
for(j = 0;j < 210;j ++)
number[i][j] = 0;
for(i = 0;i < 4;i ++)
{
head[i] = 209;
number[i][head[i]] = 1;
}
for(i = 5;i <= n;i ++)
add(i);
for(j = head[n%4];j <= 209;j ++)
{
if(number[n%4][j] == 0)
printf("0000000000");
else
{
//printf("%I64d",number[n%4][j]);
sprintf(buffer,"%I64d",number[n%4][j]);
if(j==head[n%4])
printf("%s",buffer);
else
printf("%010s",buffer); // 需要补0
}
}
printf("\n");
}
return 0;
}
灵慕风
2012-06-17 · TA获得超过446个赞
知道小有建树答主
回答量:315
采纳率:100%
帮助的人:218万
展开全部
基本功能描述下吧,不知道要做什么,debug代码很费时间;我把你的程序运行了一下,确实有问题,但是没有任何注释或者说明,就得一句一句地去猜你要做什么。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式