Problem F: Exponentiation

本文详细介绍了一种解决大数幂运算的算法实现,通过去除小数点、整数部分相乘并再次添加小数点的方式,精确计算R^n(0.0<R<99.999且0<n≤25)的值。该算法适用于需要高精度计算的场景,如国家债务等经济计算。

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

Problem F: Exponentiation
Time Limit: 1 Sec Memory Limit: 128 MB
Submit: 4 Solved: 2
[Submit][Status][Web Board] [Edit] [TestData]
Description
Problems involving the computation of exact values of very large magnitude and precision are common. For example, the computation of the national debt is a taxing experience for many computer systems.

This problem requires that you write a program to compute the exact value of Rn where R is a real number ( 0.0 < R < 99.999) and n is an integer such that $0 < n \le 25$.

Input
The input will consist of a set of pairs of values for R and n. The R value will occupy columns 1 through 6, and the n value will be in columns 8 and 9.

Output
The output will consist of one line for each line of input giving the exact value of Rn. Leading zeros and insignificant trailing zeros should be suppressed in the output.

Sample Input
95.123 12
0.4321 20
5.1234 15
6.7592 9
98.999 10
1.0100 12
Sample Output
548815620517731830194541.899025343415715973535967221869852721
.00000005148554641076956121994511276767154838481760200726351203835429763013462401
43992025569.928573701266488041146654993318703707511666295476720493953024
29448126.764121021618164430206909037173276672
90429072743629540498.107596019456651774561044010001
1.126825030131969720661201
主要思路是:几的几次方。实际上也就是大数相乘,先把小数点去掉,然后相乘,最后再把小数点加上。比如说的 a 的 n 次方,那先把字符数组a里面的东西,赋值给字符数组b,然后 a 和 b 进行运算,乘的结果放到sum数组里,然后整型的 sum 数组里的每个元素转换成字符型的,赋值给字符数组b,然后再和 a数组运算,运算的次数和你输入的几次方有关系。。然后再进行细节方面的问题……

#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
int main()
{
    char a[1000];
    char b[1000];//和字符数组a一样的
    int n,i,j,k,lena,lenb,g,g1,h,ji1,ji2;
    int sum[1001];
    char s[1002];
    while(scanf("%s%d",&a,&n)!=EOF)
    {
        if(n==1)
             cout<<a<<endl;
       else
       {
           int count=0;
        memset(sum,0,sizeof(sum));
        lena=strlen(a);
        for(i=0;i<lena;i++)
        {
           if(a[i]=='.')
           {
               count=lena-i-1;//小数点后面几位
            for(j=i;j<lena-1;j++)
            {
                a[j]=a[j+1];
            }
            a[j]='\0';
            lena--;          //变成没有小数点的数
            break;
           }
        }
        count=count*n;//经过处理小数点最终有count位
        for(i=0;i<lena;i++)
        {
            b[i]=a[i];
        }
        b[i]='\0';
        lenb=strlen(b);
         for(i=1;i<=n-1;i++)
           {
                memset(sum,0,sizeof(sum));
               g=1000;g1=1000;
          for(j=lenb-1;j>=0;j--)//下面的乘数
          {
              for(k=lena-1;k>=0;k--)//上面的乘数
              {
                  sum[g--]+=(a[k]-'0')*(b[j]-'0');
              }
              g1--;
              g=g1;
          }
          for(k=1000;k>=1;k--)
          {
              sum[k-1]+=sum[k]/10;
              sum[k]=sum[k]-sum[k]/10*10;
          }
         int start=0;  
         int l=0;
         while(!sum[start] &&start<=999)
             start++;
           for(h=start;h<=1000;h++)
           {
                 b[l++]=sum[h]+'0';
           }
           b[l]='\0';
          lenb=strlen(b);
      }
    if(count!=0)
    {
        for(g=0;g<=1000;g++)
            s[g]=sum[g]+'0';
        s[1002]='\0';
        for(i=1000;i>1000-count;i--)
            s[i+1]=s[i];
        s[i+1]='.';
      for(i=0;i<=1002;i++)
      {
          if(s[i]!='0')
          {
              ji1=i;
              break;
          }
      }
      for(i=1001;i>=0;i--)
      {
          if(s[i]!='0')
          {
              ji2=i;
              break;
          }
      }
      for(i=ji1;i<=ji2;i++)
          cout<<s[i];
      cout<<endl;
    }
    else
        cout<<b<<endl;
    }
   }
    return 0;
}

 

转载于:https://www.cnblogs.com/NYNU-ACM/p/4236896.html

Windows 系统修复工具主要用于解决 Windows 11/10 系统中的各种常见问题,具有操作简单、功能全面等特点: 文件资源管理器修复:可解决文件资源管理器卡死、崩溃、无响应等问题,能终止崩溃循环。还可修复右键菜单无响应或选项缺失问题,以及重建缩略图缓存,让图片、视频等文件的缩略图正常显示,此外,还能处理桌面缺少回收站图标、回收站损坏等问题。 互联网和连接修复:能够刷新 DNS 缓存,加速网页加载速度,减少访问延迟。可重置 TCP/IP 协议栈,增强网络连接稳定性,减少网络掉线情况,还能还原 Hosts 文件,清除恶意程序对网络设置的篡改,保障网络安全,解决电脑重装系统后网络无法连接、浏览器主页被篡改等问题。 系统修复:集成系统文件检查器(SFC),可自动扫描并修复受损的系统文件。能解决 Windows 激活状态异常的问题,还可重建 DLL 注册库,恢复应用程序兼容性,解决部分软件无法正常运行的问题,同时也能处理如 Windows 沙箱无法启动、Windows 将 JPG 或 JPEG 保存为 JFIF 等系统问题。 系统工具维护:提供启动管理器、服务管理器和进程管理器等工具,用户可控制和管理启动程序、系统服务和当前运行的进程,提高系统的启动和运行速度,防止不必要的程序和服务占用系统资源。还能查看系统规格,如处理器线程数、最大显示分辨率等。 故障排除:集成超过 20 个微软官方诊断工具,可对系统问题进行专业排查,还能生成硬件健康状态报告。能解决搜索和索引故障、邮件和日历应用程序崩溃、设置应用程序无法启动等问题,也可处理打印机、网络适配器、Windows 更新等相关故障。 其他修复功能:可以重置组策略设置、catroot2 文件夹、记事本等多种系统设置和组件,如重置 Windows 应用商店缓存、Windows 防火墙设置等。还能添加重建图标缓存支持,恢复粘滞便笺删除
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值