POJ-1001

来源:http://poj.org/problem?id=1001&lang=zh-CN

这题没什么算法可言,主要是各种情况的处理。

思路:先忽略小数点,算完后输出时在适当的位置输出一个小数点就行了,完全按照高精度乘单精度的方法。至于小数点的输出,因为每乘一次带小数点的数,小数位数相加就是了。

给出几种特殊情况:

25         2

25.0      2

0.1        3

输出的结果应该是:

625

625

.001

注意好这几种情况基本上AC了。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <string>
using namespace std;

int a[100];
int pre,dd;

void doit(string s)   //把字符串存储到数组a中
{
    dd=0;
    memset(a,0,sizeof(a));

    int kk=0;      //判断输入的数据有没有小数点
    while (s[kk]!='.' && kk<s.length()) kk++;
    if (kk==s.length()) a[0]=s.length();
    else a[0]=s.length()-1;

    int h;
    for (h=0;h<s.length() && s[h]!='.';h++)
    {
        dd=dd*10+s[h]-'0';
        a[a[0]-h]=s[h]-'0';
    }

    //pre存储小数点的位置
    if (h==s.length()) {pre=0; return;}

    pre=s.length()-h-1;
    for (int i=h+1;i<s.length();i++)
    {
        a[a[0]-i+1]=s[i]-'0';
        dd=dd*10+s[i]-'0';
    }
}

void work()
{
    for (int i=1;i<=a[0];i++)
    {
        a[i]=a[i]*dd;
        if (i!=1) { a[i]+=a[i-1]/10;a[i-1]%=10; }  //因为只用了一个数组,所以进位要这样写
    }
    while (a[a[0]]>9)    //处理位数问题
    {
        a[a[0]+1]=a[a[0]]/10;
        a[a[0]]%=10;
        a[0]++;
    }
}

int main()
{
    string R; int n;
    while (cin>>R>>n)
    {
        doit(R);
        for (int i=1;i<n;i++)
            work();

        for (int i=a[0];i>pre*n;i--)  //输出整数部分
            printf("%d",a[i]);
        int xx=1;
        while (a[xx]==0) xx++;   //把多余的0去掉
        if (xx<=pre*n)          //处理没有小数点的情况
        {
            printf(".");
            for (int i=pre*n;i>=xx;i--)
                printf("%d",a[i]);
        }
        printf("\n");
    }
    return 0;
}
posted @ 2012-12-11 13:02  ay27  阅读(134)  评论(0编辑  收藏  举报