原题链接:蓝桥杯算法提高VIP-实数相加
#include<iostream> #include<algorithm> #include<string> using namespace std; const int N=200; int idx1,idx2; int a[N],am[N],b[N],bm[N],c[N],cm[N]; void print() { for(int i=a[0];i>=1;i--) cout<<a[i]; if(idx1!=-1) { cout<<'.'; for(int i=1;i<=am[0];i++) cout<<am[i]; } cout<<endl; for(int i=b[0];i>=1;i--) cout<<b[i]; if(idx2!=-1) { cout<<'.'; for(int i=1;i<=bm[0];i++) cout<<bm[i]; } cout<<endl; } int main(void) { //freopen("D:\\input4.txt","r",stdin); string str1,str2; cin>>str1>>str2; int len1=str1.length(); int len2=str2.length(); idx1=-1,idx2=-1; for(int i=0;i<len1;i++) { if(str1[i]=='.') { idx1=i; break; } } for(int i=0;i<len2;i++) { if(str2[i]=='.') { idx2=i; break; } } if(idx1==-1) { a[0]=len1; for(int i=1;i<=a[0];i++) a[i]=str1[a[0]-i]-'0'; } else { a[0]=idx1; for(int i=1;i<=a[0];i++) a[i]=str1[a[0]-i]-'0'; } if(idx2==-1) { b[0]=len2; for(int i=1;i<=b[0];i++) b[i]=str2[b[0]-i]-'0'; } else { b[0]=idx2; for(int i=1;i<=b[0];i++) b[i]=str2[b[0]-i]-'0'; } if(idx1!=-1 || idx2!=-1) am[1]=bm[1]=0;//初始化 if(idx1!=-1) { am[0]=len1-idx1-1; for(int i=1;i<=am[0];i++) am[i]=str1[i+idx1]-'0'; } if(idx2!=-1) { bm[0]=len2-idx2-1; for(int i=1;i<=bm[0];i++) bm[i]=str2[i+idx2]-'0'; } //print(); c[0]=max(a[0],b[0])+1; for(int i=1;i<=c[0];i++) { c[i]+=a[i]+b[i]; if(c[i]>=10) { c[i+1]++; c[i]%=10; } } while(c[0]>1 && c[c[0]]==0) c[0]--; cm[0]=max(am[0],bm[0]); int x=0; for(int i=cm[0];i>=1;i--) { cm[i]+=am[i]+bm[i]+x; x=cm[i]/10; if(cm[i]>=10) { cm[i]%=10; } } if(x!=0) { c[1]++; c[0]++; int idx=1; while(c[idx]>=10) { c[idx+1]++; c[idx]%=10; } while(c[0]>1 && c[c[0]]==0) c[0]--; } for(int i=1;i<=c[0];i++) cout<<c[c[0]-i+1]; if(idx1!=-1 || idx2!=-1) { cout << '.'; for(int i=1;i<=cm[0];i++) cout<<cm[i]; } return 0; }
解题思路:
注意事项:
参考代码:
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复