C/C++编程小练习 大数减法之浮点大数减法算法
2016-12-27 19:47
417 查看
#include <iostream> #include <cstring> using namespace std; void reverse_str(char *a,int size){ for(int i=0;i<size/2;++i){ char t=a[i]; a[i]=a[size-i-1]; a[size-i-1]=t; } } int f_to_i(char *a,char *c){//将浮点数字符串转化为整形字符串,并返回浮点数小数部分的长度 int len=strlen(a); char *p1=a; char *p2=NULL; for(int i=0;i<len;++i){ if(a[i]=='.'){ a[i]='\0'; p2=&a[i+1]; break; } } strcat(p1,p2); strcpy(c,p1); return strlen(p2)+1; } //核心算法和我的浮点大数加法一样,就是按照小数点的位置做对齐处理,小数部分不够的补0,然后将其当作大整数减法来处理 void large_float_sub(char a[],char b[],char c[]){ char p1[20000]={0}; char p2[20000]={0}; int pos1=f_to_i(a,p1); int pos2=f_to_i(b,p2); int max_pos; if(pos1>pos2){ int t=pos1-pos2; int len=strlen(p2); int i; for(i=0;i<t;++i){ p2[i+len]='0'; } p2[i+len]='\0'; max_pos=pos1; }else{ int t=pos2-pos1; int len=strlen(p1); int i; for(i=0;i<t;++i){ p1[len+i]='0'; } p1[i+len]='\0'; max_pos=pos2; } int a_len=strlen(p1); int b_len=strlen(p2); reverse_str(p1,a_len); reverse_str(p2,b_len); int max_len=a_len>b_len?a_len:b_len; if(a_len>b_len){ for(int i=0;i<a_len||i<b_len;++i){ c[i]+=p1[i]-p2[i]; if(i>=a_len||i>=b_len){ c[i]-='0'; } if(c[i]<0){ c[i]+=10; c[i+1]-=1; } } }else if(a_len<b_len){ cout<<"-"; for(int i=0;i<a_len||i<b_len;++i){ c[i]+=p2[i]-p1[i]; if(i>=a_len||i>=b_len){ c[i]-='0'; } if(c[i]<0){ c[i]+=10; c[i+1]-=1; } } }else{ if(strcmp(a,b)>=0){ for(int i=0;i<a_len||i<b_len;++i){ c[i]+=p1[i]-p2[i]; if(i>=a_len||i>=b_len){ c[i]-='0'; } if(c[i]<0){ c[i]+=10; c[i+1]-=1; } } }else{ cout<<"-"; for(int i=0;i<a_len||i<b_len;++i){ c[i]+=p2[i]-p1[i]; if(i>=a_len||i>=b_len){ c[i]-='0'; } if(c[i]<0){ c[i]+=10; c[i+1]-=1; } } } } int j; for(j=max_len;j>0;--j){//去掉前导0 if(c[j]!=0){ break; } } for(int i=j;i>=max_pos;--i){ cout<<(int)c[i]; } cout<<"."; for(int i=max_pos-1;i>=0;--i){ cout<<(int)c[i]; } cout<<endl; } int main(){ char a[20000]={0}; char b[20000]={0}; char c[40001]={0}; cin>>a; cin>>b; large_float_sub(a,b,c); return 0; }
相关文章推荐
- [算法导论]2.2节编程练习C++实现
- C/C++编程小练习 大数阶乘
- [算法导论]2.1节编程练习C++实现
- C/C++编程小练习 计算10亿之内的素数和(合数筛选算法实现)
- 2018年全国多校算法寒假训练营练习比赛(第三场)---E---题(大数阶乘(模板题)c++/java/py)
- C++ 编程练习3
- 【C++ Primer Plus 编程练习】 2.7
- C++基础编程练习14
- c++基础编程练习13
- C/C++语言最新华为机试题“大数相加算法”
- 算法(第四版 Robert Sedgewick)课后练习答案 1.1 基础编程模型
- C++ 编程练习1
- 算法练习之二叉查找树 C++实现
- Linux C/C++ 编程练手 --- 大数相加和大数相乘
- C/C++笔试题-主要考察C/C++语言基础概念、算法及编程,附参考答案,分享给大家
- C++ Primer Plus(第6版) 第7章 编程练习
- 【C++ Primer Plus 编程练习】 3.7
- 算法 - 有两个相同大小数组均已按升序排列好,编程计算这两个数组的中位数(C++)
- 算法和编程题目(C/C++/Shell)
- c++基础编程练习17