POJ 1001

博客记录了2018年8月28日关于POJ 1001的相关内容,但未详细说明具体信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2018/8/28

POJ 1001

#include <iostream>
#include <cstring>
#include <stdio.h>
#include <stdlib.h>
#include <cmath>
#include <map>
#include <algorithm>
using namespace std;

int main()
{
    char s[10];
    int n;
    while(scanf("%s%d", s, &n) != EOF){
        if(n == 0){
            printf("1\n");
            continue;
        }
        int r[10], p = 0;
        for(int i = strlen(s) - 1, j = 0; i >= 0; i--){  //转化成数字倒序存放
            if(s[i] == '.'){
                p = (strlen(s) - 1 - i) * n;
                i--;
            }
            r[j] = s[i] - '0';
            j++;
        }

        int t[1000], t_len = 5, k = 4;
        memcpy(t, r, sizeof(int) * 5);
        while(--n){
            int sum[1000] = {0};
            for(int i = 0; i < 5; i++){          // r * t两两相乘
                int temp = 0;
                k = i;
                for(int j = 0; j < t_len; j++){
                    sum[k] = r[i] * t[j] + temp + sum[k];
                    int mid_sum = sum[k];
                    if(sum[k] > 9){
                        sum[k] = sum[k] % 10;
                        temp = mid_sum / 10;
                    }
                    else
                        temp = 0;
                    k++;
                    if(k == t_len + i)
                        sum[k] = temp;
                }
            }
            for(int m = 0; m <= k; m++)
                t[m] = sum[m];
            t_len = k + 1;
        }

        int temp1 = 0, temp2 = k;
        for(int i = 0; i <= k; i++){        //去后缀0
            if(t[i] != 0){
                temp1 = i;
                if(temp1 > p)
                    temp1 = p;
                break;
            }
        }
        for(int i = k; i >= 0; i--){        //去小数点前的0
            if(t[i] != 0){
                temp2 = i;
                if(p > temp2)
                    temp2 = p - 1;         //这里注意
                break;
            }
        }
        for(int i = temp2; i >= temp1; i--){
            if(i == p - 1)
                printf(".");
            printf("%d", t[i]);
        }
        printf("\n");
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值