Aaron-NZH 2018-12-25 15:10 采纳率: 33.3%
浏览 251

北大oj1001,求求路过的大佬帮我看看为什么不能ac

#include
#include

void multiply(int* n1,int* n2); //n1*n2,并且将结果放到n2

int main()
{
char r[7];
int n,i,j,point,res[250],num[5];
int len =250;
while(scanf("%s%d",r,&n)!=EOF)
{
point = 0;
while(r[point]!='.')point++; //point=小数点之前的数位
for(i=point;i r[i]=r[i+1];
point = 5-point;
point *= n; //最终结果小数点最多有 point位
for(i=4;i>=0;i--)
num[4-i] = r[i]-'0';
memset(res,0,sizeof(res));
res[0] = 1;
for(i=0;i multiply(num,res);
while(res[len])
{
len--;
}
while(res[len] == 0)
{
len--;
}
for(i=len;i>=point;i--)
printf("%d",res[i]);
for(i=0;i if(res[i]!=0)
break;
if(i {
printf(".");
for(j=point-1;j>=i;j--)
printf("%d",res[j]);
}
printf("\n");
}
return 0;
}

void multiply(int* n1,int* n2)
{
int i,j,tmp[250];
memset(tmp,0,sizeof(tmp));
for(i=0;i<5;i++)
for(j=0;j<250;j++)
tmp[i+j] += n1[i] * n2[j];
for(i=0;i<250;i++){
tmp[i+1] += tmp[i]/10;
tmp[i] %= 10;
}
memcpy(n2,tmp,sizeof(tmp));
}

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 高德地图点聚合中Marker的位置无法实时更新
    • ¥15 DIFY API Endpoint 问题。
    • ¥20 sub地址DHCP问题
    • ¥15 delta降尺度计算的一些细节,有偿
    • ¥15 Arduino红外遥控代码有问题
    • ¥15 数值计算离散正交多项式
    • ¥30 数值计算均差系数编程
    • ¥15 redis-full-check比较 两个集群的数据出错
    • ¥15 Matlab编程问题
    • ¥15 训练的多模态特征融合模型准确度很低怎么办