UVa 202 Repeating Decimals

循环小数算循环节什么的

手动算了一个1/7之后思路很清晰

循环节最大长度不会超过分母



why?多算几个循环小数你就懂了

刚开始是每出一个除数就往前查找,如果有一样的就break

但是混循环的小数过不了

一怒之下改为循环到底

这下混循环过了

循环节为一的bug了

然后加个判断

还有分子为0和能整除的特殊情况

都分开讨论一下

(补丁式A题

所以代码有点乱


#include<cstdio>
using namespace std;

int main(){
    int up,down=0;
    while(~scanf("%d %d",&up,&down)){
        int arr[2][3005]={0};
        int len=0,st=0;
        int k=up;
        while(len<down+3){
            arr[0][len]=up/down;
            up=arr[1][len]=up%down;
            if(!up)
                break;
            len++;
            up=up*10;
        }
        for(int i=1;i<len;i++){
            for(int j=i+2;j<len;j++)
                if(arr[1][j]==arr[1][i] && arr[0][j]==arr[0][i]){
                    len=j;
                    st=i;
                    break;
                }
        }
        if(len-st==2 && arr[1][len]==arr[1][len-1])
            len--;
        if(up==0){
            len+=2;
            st=len-1;
        }
        printf("%d/%d = %d.",k,down,arr[0][0]);
        for(int i=1;i<len;i++){
            if(i==st) printf("(");
            printf("%d",arr[0][i]);
            if(i>49){
                printf("...");
                break;
            }
        }
        printf(")\n");
        printf("   %d = number of digits in repeating cycle\n\n",len-st);
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值