您的位置:首页 > 其它

【USACO 2.4】Fractions to Decimals(分数转小数)

2016-11-15 16:27 507 查看
题意:给你N/D的分数,让你输出等价的小数,如果是循环小数,用括号把循环节包起来。如果是整数,后面保留一位小数。每行最多输出76个字符。

题解:模拟除法,如果余数是第二次出现,则代表第一次出现的位置到此为循环节,注意输出,注意输出格式,注意输出每行最多76个字符。学习了一下题解的写法,先写入字符串ans,最后76个一行输出的就很好写了。

/*
TASK: fracdec
LANG:C++
*/
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 100100
using namespace std;
int n,d,p
;
char ans
,dec
;
int main(){
freopen("fracdec.in","r",stdin);
freopen("fracdec.out","w",stdout);
scanf("%d%d",&n,&d);
sprintf(ans,"%d.",n/d);
n%=d;
memset(p,-1,sizeof p);
for(int i=0;;i++){
p
=i;
n*=10;
dec[i]=n/d+'0';
n%=d;
if(!n){
sprintf(ans+strlen(ans),"%s",dec);
break;
}
if(p
!=-1){
sprintf(ans+strlen(ans),"%.*s(%s)",p
,dec,dec+p
);
break;
}
}
for(int i=0;ans[i];i+=76)
printf("%.76s\n",ans+i);
return 0;
}


  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: