1873 初中的算术 (51nod)高精度计算

1873 初中的算术 

基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题

 收藏

 关注

Noder现在上初三了,正在开始复习中考。他每天要计算型如 (a× a× a× ⋯× a)n个a 的式子。 其中 0.0<a<99.999,0<n<26 。

虽然Noder会计算,但是老是算错,现在他想要你来写一个程序输出正确的结果,以便他核对。

 

Input

单组测试数据。
第一行有一个实数a和一个整数n,中间用空格分开。 0.0 < a < 99.999,a总是占6位(a长度<=6),0<n<26。

Output

输出一个实数表示结果,不要输出前导0,后面多余的0也不要输出,如果是整数不要输出小数点。

Input示例

样例输入1
0.4321 20
样例输入2
1.0100 12

Output示例

样例输出1
.00000005148554641076956121994511276767154838481760200726351203835429763013462401
样例输出2
1.126825030131969720661201
#include<stdio.h>
#include<string>
#include<algorithm>
#include<string.h>
#include<iostream>
using namespace std;
string multi(string a,string b)
{
	int i,j,arr[200],len=a.length()+b.length();
	memset(arr,0,sizeof(arr));
	reverse(a.begin(),a.end());
	reverse(b.begin(),b.end());
	for(int i=0;i<a.length();i++)
	{
		for(int j=0;j<b.length();j++)
		{
			arr[i+j]+=(a[i]-'0')*(b[j]-'0');
		 } 
	}
	for(int i=0;i<len;i++)
	{
		arr[i+1]+=arr[i]/10;
		arr[i]%=10;
	}
	string ret=string(len,'0');
	for(int i=0;i<len;i++)
	{
		ret[i]+=arr[i];
	}
	reverse(ret.begin(),ret.end());
	return ret;
 } 
 string Str_Pow(string x,int p)
 {
 	string ret="1";
 	while(p)
 	{
 		if(p&1) ret=multi(ret,x);
 		x=multi(x,x);
 		p>>=1;
	 }
	 return ret;
 }
int main()
{
	string a;
	int n;
	cin>>a>>n;
	
		int index=a.find('.');
		if(index==-1) index=0;
		else{
			a=a.substr(0,index)+a.substr(index+1);
			index=(a.length()-index)*n;
		}
		a=Str_Pow(a,n);
		a=a.substr(0,a.length()-index)+"."+a.substr(a.length()-index);
		int i;
		for(i=0;i<a.length();i++)
		{
			if(a[i]!='0')break;
		}
		a=a.substr(i);
		for(int i=a.length()-1;i>=0;i--)
		{
			if(a[i]=='.') {
			a=a.substr(0,i);
			break;}
			else if(a[i]!='0')
			{
				a=a.substr(0,i+1);
				break;
			}
		}
		cout<<a<<endl;
	
	return 0;
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值