#给牛客的问题反馈和建议#
高精度整数加法这个题目是不是有问题?我自己手动输入好几组数据都算出来是对的,为什么一提交就算出奇怪的数字
全部评论
代码 #include<stdio.h> #include<string.h> int main() { char num1[10000]; while(gets(num1)) { char num2[10000]; char tmp[10000]; gets(num2); int len1=strlen(num1)>strlen(num2)?strlen(num1):strlen(num2); int len2=strlen(num1)>strlen(num2)?strlen(num2):strlen(num1); int stack[10000]={0};int jinwei=0;int i,j,k; int len; int cot=0; if(len1==len2&&num1[0]-'0'+num2[0]-'0'>=10) { len=len1; } else { len=len1-1; } if(strlen(num1)<strlen(num2)) { strcpy(tmp,num1); strcpy(num1,num2); strcpy(num2,tmp); } j=len+1;k=len2; len2--; for(i=len1-1;i>=0;i--) { cot++; if(jinwei&&len2!=-1) { stack[len--]=(num1[i]-'0')+(num2[len2--]-'0')+1; jinwei=0; } else{ stack[len--]=(num1[i]-'0')+(num2[len2--]-'0'); } if(stack[len+1]>=10) { jinwei=1; stack[len+1]%=10; } if(jinwei&&len2==-1) { stack[i]++; } if(len2<0&&cot<len1) { for(k=i-1;k>=0;k--) { stack[len--]=num1[k]-'0'; } break; } } for(int u=0;u<=j-1;u++) { stack[u]+='0'; printf("%c",stack[u]); } printf("\n"); memset(num2,0,10000); memset(num1,0,10000); memset(tmp,0,10000); memset(stack,0,10000); } return 0; }
点赞 回复 分享
发布于 2021-05-30 16:44

相关推荐

totoroyyw:千年老妖😂
投递华为等公司10个岗位
点赞 评论 收藏
分享
双非一本失业第二年:《机器视觉垃圾分类》
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-26 18:54
说等下个版本吧的发呆爱好者很贪睡:佬最后去了哪家呀
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务