C++中高精度计算的问题
我想要计算,比如67.43的21次方,下面是我编的程序#include"iostream.h"#include<iomanip.h>voidmain(){doublea,...
我想要计算,比如67.43的21次方,下面是我编的程序
# include "iostream.h"
# include <iomanip.h>
void main(){
double a,b=1;
a=67.34;
for(int i=1;i<=21;i++)
b=b*a;
cout<<setiosflags(ios::fixed)<<b;
}但程序不能正常显示,要怎么改才能在屏幕上输出精确的的结果呢??(不要把小数省略,要完整的结果。)
请真正的高手帮帮忙啊 展开
# include "iostream.h"
# include <iomanip.h>
void main(){
double a,b=1;
a=67.34;
for(int i=1;i<=21;i++)
b=b*a;
cout<<setiosflags(ios::fixed)<<b;
}但程序不能正常显示,要怎么改才能在屏幕上输出精确的的结果呢??(不要把小数省略,要完整的结果。)
请真正的高手帮帮忙啊 展开
展开全部
高精度运算一般是用数组来储存各位的数字,然后模拟手工算法来计算的.直接用double型的精度是不够的。
这是我以前写的一个程序.如果是0.2321的话就只输出.2321
#include"iostream"
#include"string"
#include"vector"
using namespace std;
struct longfloat{
longfloat(){num=vector<short>(0);point=0;}
longfloat(int n){num=vector<short>(n,0);point=0;}
vector<short>num;
int point;
};
istream& operator>>(istream&sin,longfloat&r){
string s;
sin>>s;
r.point=s.size()-1-s.find(".",0);
r.num=vector<short>(0);
for(int i=s.size()-1;i>=0;i--){
if(s[i]!='.')r.num.push_back(s[i]-'0');
}
return sin;
}
ostream& operator<<(ostream&sout,longfloat r){
while(r.num[r.num.size()-1]==0&&r.num.size()>r.point)r.num.pop_back();
int n=0;
while(r.num[n]==0)n++;
for(int i=r.num.size()-1,j=0;i>=n;i--,j++){
if(j==r.num.size()-r.point)sout<<".";
sout<<r.num[i];
}
return sout;
}
longfloat operator*(const longfloat&r1,const longfloat&r2){
longfloat tem(r1.num.size()+r2.num.size()-1);
tem.point=r1.point+r2.point;
for(int i=0;i<r1.num.size();i++){
for(int j=0;j<r2.num.size();j++){
tem.num[i+j]+=r1.num[i]*r2.num[j];
}
}
for(int i=0;i<tem.num.size()-1;i++){
if(tem.num[i]>=10){
tem.num[i+1]+=tem.num[i]/10;
tem.num[i]%=10;
}
}
while(tem.num[tem.num.size()-1]>=10){
tem.num.push_back(tem.num[tem.num.size()-1]/10);
tem.num[tem.num.size()-2]%=10;
}
return tem;
}
longfloat pow(longfloat r,int n)
{
longfloat tem=r;
for(int i=1;i<n;i++){
r=r*tem;
}
return r;
}
int main()
{
longfloat r;
int n;
while(cin>>r>>n){
cout<<pow(r,n)<<endl;
}
}
这是我以前写的一个程序.如果是0.2321的话就只输出.2321
#include"iostream"
#include"string"
#include"vector"
using namespace std;
struct longfloat{
longfloat(){num=vector<short>(0);point=0;}
longfloat(int n){num=vector<short>(n,0);point=0;}
vector<short>num;
int point;
};
istream& operator>>(istream&sin,longfloat&r){
string s;
sin>>s;
r.point=s.size()-1-s.find(".",0);
r.num=vector<short>(0);
for(int i=s.size()-1;i>=0;i--){
if(s[i]!='.')r.num.push_back(s[i]-'0');
}
return sin;
}
ostream& operator<<(ostream&sout,longfloat r){
while(r.num[r.num.size()-1]==0&&r.num.size()>r.point)r.num.pop_back();
int n=0;
while(r.num[n]==0)n++;
for(int i=r.num.size()-1,j=0;i>=n;i--,j++){
if(j==r.num.size()-r.point)sout<<".";
sout<<r.num[i];
}
return sout;
}
longfloat operator*(const longfloat&r1,const longfloat&r2){
longfloat tem(r1.num.size()+r2.num.size()-1);
tem.point=r1.point+r2.point;
for(int i=0;i<r1.num.size();i++){
for(int j=0;j<r2.num.size();j++){
tem.num[i+j]+=r1.num[i]*r2.num[j];
}
}
for(int i=0;i<tem.num.size()-1;i++){
if(tem.num[i]>=10){
tem.num[i+1]+=tem.num[i]/10;
tem.num[i]%=10;
}
}
while(tem.num[tem.num.size()-1]>=10){
tem.num.push_back(tem.num[tem.num.size()-1]/10);
tem.num[tem.num.size()-2]%=10;
}
return tem;
}
longfloat pow(longfloat r,int n)
{
longfloat tem=r;
for(int i=1;i<n;i++){
r=r*tem;
}
return r;
}
int main()
{
longfloat r;
int n;
while(cin>>r>>n){
cout<<pow(r,n)<<endl;
}
}
展开全部
67.43的21次方的结果太大了,超过了存储的最大值,所以要显示的话,可以用科学计数来显示,改为cout<<setiosflags(ios::scientific)<<b<<endl;
如果结果不是特别大,没有超过最大值,可以指定小数的位数:cout<setprecision(20)<<b<<endl; 即表示小数位数为20位。
而你用的cout<<setiosflags(ios::fixed)<<b;
表示设置浮点数以固定的小数位数显示,即小数位以系统默认的位数显示,即小数只显示6位。
如果结果不是特别大,没有超过最大值,可以指定小数的位数:cout<setprecision(20)<<b<<endl; 即表示小数位数为20位。
而你用的cout<<setiosflags(ios::fixed)<<b;
表示设置浮点数以固定的小数位数显示,即小数位以系统默认的位数显示,即小数只显示6位。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个程序可以满足你的要求,
可以计算大数的阶乘:
#pragma
hdrstop
#include<iostream.h>
#include<iomanip.h>
#include<conio.h>
#define
wan
10000
//以10000为进制,进制越大,速度越快但同时算的数也越小;
#define
endflag
999999
//结束标志
typedef
unsigned
int
intt
;
//---------------------------------------------------------------------------
int
main(int
argc,
char*
argv[])
{
cout<<"求任意正整数的阶乘";
do
{
cout<<endl<<"请输入一正整数:";
int
num;
cin>>num;
int
modulus=2;
//内存分配系数,此处有待求精
if
(num>=20000)modulus=4;
intt
*array=new
intt[num*modulus+3];
//动态分配存放结果的数组
int
endbit=0;
//记录数组的最高有效位位
array[0]=1;
array[1]=endflag;
for(;num>=1;num--)
{
intt
buff=0,carry=0;
int
i=0;
do{
buff=array[i]*num+carry;
carry=buff/wan;
array[i]=buff%wan;
i++;
if
(carry&&array[i]==endflag)
//当i位已是最高有效位而且又i-1位的进位
{
array[i+1]=endflag;
//将i+1位初始化为endflag
array[i]=0;
//将i位初始化为0;
endbit=i;
//将i赋值给最高有效位变量endbit;
}
}while(carry||array[i]!=endflag);
//当进位为0,或者已经到达结束标志
}//endfor
cout<<array[endbit];
//输出最高位
for(--endbit;endbit>=0;endbit--)
//依次输出其他位,高位不足四位补0
cout<<setfill('0')<<setw(4)<<array[endbit];//如果更改了进制setw()里的数值也要跟着改,进制多少个0这里就多少位
delete
[]
array;
cout<<endl<<"按esc键退出,任意键继续";
}while(getch()!=27);
return
0;
}
可以计算大数的阶乘:
#pragma
hdrstop
#include<iostream.h>
#include<iomanip.h>
#include<conio.h>
#define
wan
10000
//以10000为进制,进制越大,速度越快但同时算的数也越小;
#define
endflag
999999
//结束标志
typedef
unsigned
int
intt
;
//---------------------------------------------------------------------------
int
main(int
argc,
char*
argv[])
{
cout<<"求任意正整数的阶乘";
do
{
cout<<endl<<"请输入一正整数:";
int
num;
cin>>num;
int
modulus=2;
//内存分配系数,此处有待求精
if
(num>=20000)modulus=4;
intt
*array=new
intt[num*modulus+3];
//动态分配存放结果的数组
int
endbit=0;
//记录数组的最高有效位位
array[0]=1;
array[1]=endflag;
for(;num>=1;num--)
{
intt
buff=0,carry=0;
int
i=0;
do{
buff=array[i]*num+carry;
carry=buff/wan;
array[i]=buff%wan;
i++;
if
(carry&&array[i]==endflag)
//当i位已是最高有效位而且又i-1位的进位
{
array[i+1]=endflag;
//将i+1位初始化为endflag
array[i]=0;
//将i位初始化为0;
endbit=i;
//将i赋值给最高有效位变量endbit;
}
}while(carry||array[i]!=endflag);
//当进位为0,或者已经到达结束标志
}//endfor
cout<<array[endbit];
//输出最高位
for(--endbit;endbit>=0;endbit--)
//依次输出其他位,高位不足四位补0
cout<<setfill('0')<<setw(4)<<array[endbit];//如果更改了进制setw()里的数值也要跟着改,进制多少个0这里就多少位
delete
[]
array;
cout<<endl<<"按esc键退出,任意键继续";
}while(getch()!=27);
return
0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
高精度运算一般是用数组来储存各位的数字,然后模拟手工算法来计算的.直接用double型的精度是不够的。
这是我以前写的一个程序.如果是0.2321的话就只输出.2321
#include"iostream"
#include"string"
#include"vector"
using
namespace
std;
struct
longfloat{
longfloat(){num=vector<short>(0);point=0;}
longfloat(int
n){num=vector<short>(n,0);point=0;}
vector<short>num;
int
point;
};
istream&
operator>>(istream&sin,longfloat&r){
string
s;
sin>>s;
r.point=s.size()-1-s.find(".",0);
r.num=vector<short>(0);
for(int
i=s.size()-1;i>=0;i--){
if(s[i]!='.')r.num.push_back(s[i]-'0');
}
return
sin;
}
ostream&
operator<<(ostream&sout,longfloat
r){
while(r.num[r.num.size()-1]==0&&r.num.size()>r.point)r.num.pop_back();
int
n=0;
while(r.num[n]==0)n++;
for(int
i=r.num.size()-1,j=0;i>=n;i--,j++){
if(j==r.num.size()-r.point)sout<<".";
sout<<r.num[i];
}
return
sout;
}
longfloat
operator*(const
longfloat&r1,const
longfloat&r2){
longfloat
tem(r1.num.size()+r2.num.size()-1);
tem.point=r1.point+r2.point;
for(int
i=0;i<r1.num.size();i++){
for(int
j=0;j<r2.num.size();j++){
tem.num[i+j]+=r1.num[i]*r2.num[j];
}
}
for(int
i=0;i<tem.num.size()-1;i++){
if(tem.num[i]>=10){
tem.num[i+1]+=tem.num[i]/10;
tem.num[i]%=10;
}
}
while(tem.num[tem.num.size()-1]>=10){
tem.num.push_back(tem.num[tem.num.size()-1]/10);
tem.num[tem.num.size()-2]%=10;
}
return
tem;
}
longfloat
pow(longfloat
r,int
n)
{
longfloat
tem=r;
for(int
i=1;i<n;i++){
r=r*tem;
}
return
r;
}
int
main()
{
longfloat
r;
int
n;
while(cin>>r>>n){
cout<<pow(r,n)<<endl;
}
}
这是我以前写的一个程序.如果是0.2321的话就只输出.2321
#include"iostream"
#include"string"
#include"vector"
using
namespace
std;
struct
longfloat{
longfloat(){num=vector<short>(0);point=0;}
longfloat(int
n){num=vector<short>(n,0);point=0;}
vector<short>num;
int
point;
};
istream&
operator>>(istream&sin,longfloat&r){
string
s;
sin>>s;
r.point=s.size()-1-s.find(".",0);
r.num=vector<short>(0);
for(int
i=s.size()-1;i>=0;i--){
if(s[i]!='.')r.num.push_back(s[i]-'0');
}
return
sin;
}
ostream&
operator<<(ostream&sout,longfloat
r){
while(r.num[r.num.size()-1]==0&&r.num.size()>r.point)r.num.pop_back();
int
n=0;
while(r.num[n]==0)n++;
for(int
i=r.num.size()-1,j=0;i>=n;i--,j++){
if(j==r.num.size()-r.point)sout<<".";
sout<<r.num[i];
}
return
sout;
}
longfloat
operator*(const
longfloat&r1,const
longfloat&r2){
longfloat
tem(r1.num.size()+r2.num.size()-1);
tem.point=r1.point+r2.point;
for(int
i=0;i<r1.num.size();i++){
for(int
j=0;j<r2.num.size();j++){
tem.num[i+j]+=r1.num[i]*r2.num[j];
}
}
for(int
i=0;i<tem.num.size()-1;i++){
if(tem.num[i]>=10){
tem.num[i+1]+=tem.num[i]/10;
tem.num[i]%=10;
}
}
while(tem.num[tem.num.size()-1]>=10){
tem.num.push_back(tem.num[tem.num.size()-1]/10);
tem.num[tem.num.size()-2]%=10;
}
return
tem;
}
longfloat
pow(longfloat
r,int
n)
{
longfloat
tem=r;
for(int
i=1;i<n;i++){
r=r*tem;
}
return
r;
}
int
main()
{
longfloat
r;
int
n;
while(cin>>r>>n){
cout<<pow(r,n)<<endl;
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这题垃圾
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询