«August 2025»
12
3456789
10111213141516
17181920212223
24252627282930
31


公告

本站技术贴除标明为“原创”的之外,其余均为网上转载,文中我会尽量保留原作者姓名,若有侵权请与我联系,我将第一时间做出修改。谢谢!

             ——既瑜


天气预报(南京)


我的分类(专题)

首页(183)
【趣味文摘】(22)
【五子连珠】(13)
【技术文档】(136)
【电脑技术】(6)
【疑难问题】(1)
【我的心情】(5)


最新日志
花语(中英文对照版)
各种花的花语
NTFS格式的7个精彩问答(pconli
童言无忌,有趣得一蹋
给MM修电脑的三个步骤[转载]
J2EE 面试题综合
JAVA编程规则
[转] P2P之UDP穿透NAT的原理与
[转]词法分析器
文件加密技术
一个让人发狂的PI求解C程序
[转]直线生成算法之DDA
[转]利用内核对象----互斥量实现应用
[转]如何正确的计算文件收发进度
双机调试VC程序
[转]分治法优化大整数乘法 C++实现
浮点数值的内存结构
[转]双链表实现大整数的加法与乘法[VC
拜占廷将军问题[转]
某人的挂QQ的程序源代码,虽然没用了,拿

最新回复
回复:vc中的CString的操作
回复:[转]分治法优化大整数乘法 C++
回复:[转]分治法优化大整数乘法 C++
回复:花语(中英文对照版)
回复:基本排序算法比较与选择[转载]
回复:c++中强制类型转换操作符小结
回复:c++中强制类型转换操作符小结
何必那么执着于是大头猫还是愤怒的小鸟,淡
回复:浮点数值的内存结构
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:32位位图到24位位图的转换
dren, ages 16 and 20
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:各种花的花语

留言板
签写新留言

不是0-1背包喔
桂花的花语``
谢谢
提议
提议

统计
blog名称:★既瑜★
日志总数:183
评论数量:636
留言数量:-25
访问次数:1407474
建立时间:2005年3月12日

链接


http://www.nju.edu.cn
http://bbs.nju.edu.cn 
http://www.t7-online.com
http://www.csdn.net
http://www.91f.net
http://www.crsky.com
我的MSN BLOG 

联系我

  OICQ:215768265
  njucs2001@hotmail.com
  erichoo1982@gmail.com

 

W3CHINA Blog首页    管理页面    写新日志    退出


[【技术文档】]用大数相乘算法实现求一个有小数位的数x的n次方
既瑜(224499) 发表于 2005/7/13 9:06:35

/****************************************//*程序 pku1001*//*作者: S.Klaus *//*日期:2005-7-5*//*调试:VC6*//**************************************** ****************************************/ /*头函数 */#include<iostream.h> #include<iomanip.h>#include<stdlib.h>#include<string.h> #define max 10000/***************************************/int xn(char fnum[],int n);int fmul(char s1[],char s2[]);/***************************************/ char sum[max];char result[max]; /***************************************//*子函数计算两个数的乘积*/int fmul(char s1[],char s2[]){   int ls1,ls2;//用于存储长度,进位信息   int i=0,j,p,q,m;   int k=0,flag;   char mid[max];   //char sum[max];   ls1=strlen(s1);   ls2=strlen(s2);   //反向   j=ls1-1;   while(j>=0)   {    mid[i++]=s1[j--];   }   mid[i]=s1[ls1];   strcpy(s1,mid);   i=0;   j=ls2-1;   while(j>=0)   {    mid[i++]=s2[j--];   }   mid[i]=s2[ls2];   strcpy(s2,mid); //  cout<<s1<<endl<<s2<<endl;   //计算   for(i=0;i<max;i++)   {    sum[i]='0';   }    i=j=k=0; flag=0; p=0;q=0;   while(s2[i]!='\0') {    flag=0;     m=q;  for(m=0;m<q;m++)  {   mid[m]='0';  }  p=m;        while(s1[j]!='\0')  {           k=(s1[j]-'0')*(s2[i]-'0');     mid[p]=(flag+k)%10+'0';     flag=(flag+k)/10;     j++;p++;  }  if(flag!=0){mid[p++]=flag+'0';}        mid[p]='\0';  flag=0;  p=0;//*********************************************/    if(i==0)  {   while(mid[p]!='\0')   {    sum[p]=mid[p];    p++;   }  }  else  {        while(mid[p]!='\0')   {     k=(sum[p]-'0')+(mid[p]-'0');                 sum[p]=(k+flag)%10+'0';     flag=(k+flag)/10;     p++;        }    if(flag!=0)    {   sum[p++]=flag+'0';   flag=0;    }  }  j=0;  i++;q++; }   sum[p]='\0';   i=0;j=0;   strcpy(mid,sum);   p-=1;   while(p>=0)   {    sum[j]=mid[p];    p--;    j++;   }   sum[j]='\0';   return 0;}/***************************************/int xn(char fnum[],int n){    char s1[max]; int i; if(n==0) {  strcpy(result,"1");  return 0; } for(i=0;i<max;i++) {  result[i]='\0'; }     strcpy(result,fnum);   for(i=1;i<n;i++) {   strcpy(s1,fnum);      fmul(s1,result);   strcpy(result,sum); } return 0;}/***************************************/ /***************************************//*主函数*/ int main(){    char s1[max],s2[6]; int i; /*******************/ int n,ln,ls; char ch; int m,j=0,fl[100]; char s[6]; char res[100][max]; /*******************/ m=0; for(i=0;i<100;i++)  fl[i]=0;  while(cin>>s2>>n)  {    j=0;    i=0;   while(s2[i]!='\0') {    if(s2[i]=='.')  {   ln=strlen(s2)-1-i;   fl[m]=ln;  }    else    {     s[j++]=s2[i];    }    i++; } s[j]='\0';  ln=ln*n; xn(s,n);    ls=strlen(result);    i=0; j=0;  while(result[i]!='\0') {   if(i==(ls-ln))  {   res[m][j++]='.';      res[m][j++]=result[i++];  }  else  {           res[m][j++]=result[i++];  } } res[m][j]='\0';    m++;  } //去除多出的零  for(i=0;i<m;i++)  {   j=strlen(res[i])-1;    while(j!=0&&fl[i]!=0)   {    if(res[i][j]!='0')    {     if(res[i][j]=='.')      res[i][j]='\0';     else        res[i][j+1]='\0';     break;    }    j--;   }   j=0;   while(res[i][j]!='\0')   {    if(res[i][j]!='0')    {     while(res[i][j]!='\0')     {        cout<<res[i][j++];     }     cout<<endl;     break;    }    j++;   }  }   return 0;}

阅读全文(3356) | 回复(0) | 编辑 | 精华


发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)

站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.047 second(s), page refreshed 144756385 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号