蓝桥杯 算法提高 实数相加
来源:互联网 发布:圣火名尊法器进阶数据 编辑:程序博客网 时间:2024/06/05 16:36
算法提高 实数相加
时间限制:1.0s 内存限制:512.0MB
问题描述
计算两个实数相加的结果。
输入的实数满足如下要求: (1) 小数点前的整数部分最多100位,(2) 小数点后的小数部分最多100位.
输入的实数满足如下要求: (1) 小数点前的整数部分最多100位,(2) 小数点后的小数部分最多100位.
输入格式
两行字符串,每行都是一个合法的实数。合法的意思是指: 整数部分的值如果大于零,则最高位数字必定大于零. 如果整数部分的值为零,则整数部分只有一个零. 小数部分尾部可以有任意多的零. 可以没有小数部分, 此时也没有小数点. 如果有小数点, 则至少需要有一位小数部分, 且允许是零.
输出格式
相加结果。注意: 小数部分末尾如果有连续的0, 则它们都是有效数字, 不能舍去. 如果是两个整数相加, 则结果仍为整数而没有小数部分.
样例输入
样例一:0.0000000000000000000000000000000000000111111111000000000000000000100000000000000000000000000000000000000000000000000000.0样例二:34样例三:3.92样例四:1.0018.99999999999999999999999
样例输出
样例一:100000000000000000000000000000000000000000000000000000.0000000000000000000000000000000000000111111111000000000000000000样例二:7样例三:5.9样例四:10.00099999999999999999999
懒得写注释了。。
#include<iostream>#include<string>#include<cstring>using namespace std;int main(){string a,b;cin >>a>>b;int alen=a.length(),blen=b.length(),aplen=0,bplen=0; //aplen 小数点前的位数. int i,j,aflag=0,bflag=0,ka=0,kb=0; //ka,kb 小数点后的位数。 for(i=0;i<alen;i++){if(a[i]=='.')aflag=1;if(a[i]!='.'&&aflag==0)aplen++;if(aflag==1)ka++;}if(ka>1)ka--;for(i=0;i<blen;i++){ if(b[i]=='.')bflag=1;if(b[i]!='.'&&bflag==0)bplen++;if(bflag==1)kb++;}if(kb>1)kb--; if(aplen>bplen){for(i=0;i<aplen-bplen;i++)b="0"+b;}else{for(i=0;i<bplen-aplen;i++)a="0"+a;}if(ka>kb){if(kb==0) b+=".";for(i=0;i<ka-kb;i++)b+="0";}else{if(ka==0)a+=".";for(i=0;i<kb-ka;i++)a+="0";}int len=a.length();int plen=aplen>bplen?aplen:bplen; //小数点前 的位数。 int k=ka>kb?ka:kb; //小数点后的位数。 int s[k+1];memset(s,0,sizeof(s));int w=0;for(i=len-1;i>plen;i--,w++){s[w]+=(a[i]-'0')+(b[i]-'0');if(s[w]>9){s[w+1]++;s[w]-=10;}}if(s[w]==0)w--;int sflag=0;if(s[k]==0)sflag=0;elsesflag=1;int ss[plen+1];memset(ss,0,sizeof(ss));int ww=0;if(sflag==1)ss[ww]+=1;for(i=len-k-2;i>=0;i--,ww++){ss[ww]+=(a[i]-'0')+(b[i]-'0');if(ss[ww]>9){ss[ww+1]++;ss[ww]-=10;}}if(ss[ww]==0)ww--;for(i=ww;i>=0;i--)cout <<ss[i];if(aflag||bflag)cout <<".";for(i=k-1;i>=0;i--)cout <<s[i];return 0;}
阅读全文
0 0
- 蓝桥杯 算法提高 实数相加
- 算法提高 实数相加
- 算法提高 ADV-18 实数相加
- 实数相加_蓝桥杯
- 复数与实数的相加
- hdu1753(模拟大实数相加)
- 1.3.1提高实数精度的范例
- 遗传算法---实数编码方式
- 遗传算法---实数编码方式
- 蓝桥杯 算法提高 算法提高 最大乘积
- 蓝桥杯 算法提高 算法提高 约数个数
- 实数
- 实数
- 实数
- 用一个sumofsquare函数,辨别是两个整数相加还是两个实数相加---C++重载
- 提高项目33-矩阵相加
- 蓝桥杯 算法提高 P1003
- 蓝桥杯-算法提高-Cowboys
- Android设备ID简析
- STL源码剖析——deque的实现
- [BFS] POJ 3087
- 字符编码中的一些概念辨析
- 判断scroll是否滚动到底部以及实现回到顶部
- 蓝桥杯 算法提高 实数相加
- Vim命令合集(转)
- 大整数相加
- It's no longer allowed to omit the '-loader' suffix when using loaders.
- Kylin 2.0升级总结
- Linux学习笔记DayNote01
- 超完整的Chrome浏览器客户端调试大全
- 微信小程序页面间传值方法
- ERROR: ORA-28000: the account is locked Oracle数据库被锁