zcmu-1411
来源:互联网 发布:淘宝客服如何设置分流 编辑:程序博客网 时间:2024/06/05 16:05
1411: 喜闻乐见的a+b
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 229 Solved: 90
[Submit][Status][Web Board]
Description
喜闻乐见的a+b来了,当然二进制,八进制,十进制什么的估计你们也懒得写了,来个20进制的a+b
Input
给出多组a和b,每个数字一行
数字由0~9和小写字母a~j(10~19)
给出的长度不超过100
Output
每组数据输出a+b的和。
Sample Input
1234567890abcdefghij99999jjjjj9999900001
Sample Output
bdfi02467jiiiij00000
HINT
Source
好气的一道题,起先是反转字符,然后相加,后面再反转又输出,但是不知道为什么wa好多次,改了又改,后面删了从新写,有int数组记录后面就对了。
下面有改了有一个我改了又改的wa代码 ac代码在最下面;欢迎指出我那道wa错在哪,求大佬解释。
wa代码:
#include<cstdio>#include<cstring>#include<algorithm>using namespace std;int main(){ char s[22]={"0123456789abcdefghij"}; char a[160],b[160],ss[160]; while(~scanf("%s",a)) { scanf("%s",b); int x,y; int go=0; int la=strlen(a); int lb=strlen(b); reverse(a,a+la); reverse(b,b+lb); memset(ss,'0',sizeof(ss)); for(int i=la; i<150; i++)a[i]='0';a[150]='\n'; for(int i=lb; i<150; i++)b[i]='0';b[150]='\n'; for(int i=0; i<150; i++) { if(a[i]>='0'&&a[i]<='9')x=a[i]-'0'; else x=a[i]-'a'+10; if(b[i]>='0'&&b[i]<='9')y=b[i]-'0'; else y=b[i]-'a'+10; int z=x+y+go; //printf("%d\n",y); if(z<20){ss[i]=s[z];go=0;} else {ss[i]=s[z-20];go=1;} } ss[150]='\n'; int flag=0,i; for(i=149; i>=0; i--) { if(ss[i]!='0')break; } for(int j=i; j>=0; j--)printf("%c",ss[j]); printf("\n"); } return 0;}
ac代码:
#include<cstdio>#include<cstring>#include<algorithm>using namespace std;int main (){ char a1[10000],b1[10000]; int a[10000],b[10000],c[10000]; int k,m,n,x,ans,flag; while(~scanf("%s",a1)) { memset(a,0,sizeof(a)); memset(b,0,sizeof(b)); memset(c,0,sizeof(c)); scanf("%s",b1); int len1=strlen(a1),len2=strlen(b1); for(int i=len1-1;i>=0;i--){ if(a1[i]>='0'&&a1[i]<='9')a[len1-1-i]=a1[i]-'0'; else if(a1[i]>='a'&&a1[i]<='j')a[len1-1-i]=a1[i]-'a'+10; } for(int i=len2-1;i>=0;i--){ if(b1[i]>='0'&&b1[i]<='9')b[len2-1-i]=b1[i]-'0'; else if(b1[i]>='a'&&b1[i]<='j')b[len2-1-i]=b1[i]-'a'+10; } int len=len1; if(len<len2){len=len2;} for(int i=0;i<len;i++){ c[i]=a[i]+b[i]+c[i]; if(c[i]>=20){ c[i]=c[i]-20;c[i+1]++; } } int flag=max(len1,len2)+2; while(c[flag]==0&&flag>=0)flag--; if(flag<0)printf("0\n"); else{ for(int i=flag;i>=0;i--) { if(c[i]<=9)printf("%d",c[i]); else printf("%c",c[i]-10+'a'); } printf("\n"); } } return 0;}
阅读全文
0 0
- zcmu-1411
- zcmu-1657
- zcmu-1685
- ZCMU----1776
- ZCMU----1777
- ZCMU----1778
- ZCMU----1779
- ZCMU-1731
- ZCMU-1658
- ZCMU-1654
- ZCMU-1132
- ZCMU-1037
- ZCMU-1415
- ZCMU-1036
- ZCMU-1723
- ZCMU-1608
- ZCMU-1478
- ZCMU-1750
- bzoj2946 [Poi2000]公共串(SA+二分答案 同poj3450)
- 理解jquery的$.extend()、$.fn和$.fn.extend()
- matlab2c使用c++实现matlab函数系列教程-blkdiag函数
- json数组生成器-jquery
- 算法的时间复杂度和空间复杂度-总结
- zcmu-1411
- zabbix的在线安装
- HTTP深入浅出 http请求
- python实现-合并表记录
- 安卓SystemUI定制
- CentOS7.2搭建Go语言开发环境
- ubuntu16.04+gtx1080ti+caffe安装记录
- Java值传递和引用传递
- 刷题——hdu 6180 Schedule