题目描述:
    读入两个不超过25位的火星正整数A和B,计算A+B。需要注意的是:在火星上,整数不是单一进制的,第n位的进制就是第n个素数。例如:地球上的10进制数2,在火星上记为“1,0”,因为火星个位数是2进制的;地球上的10进制数38,在火星上记为“1,1,1,0”,因为火星个位数是2进制的,十位数是3进制的,百位数是5进制的,千位数是7进制的……
输入:
    测试输入包含若干测试用例,每个测试用例占一行,包含两个火星正整数A和B,火星整数的相邻两位数用逗号分隔,A和B之间有一个空格间隔。当A或B为0时输入结束,相应的结果不要输出。
输出:
    对每个测试用例输出1行,即火星表示法的A+B的值。
样例输入:
1,0 2,1
4,2,0 1,2,0
1 10,6,4,2,1
0 0
样例输出:
1,0,1
1,1,1,0
1,0,0,0,0,0
这道题比较诡异,题目中说两个不超过25位的A,B是指int数组不超过25位,而转化为char后就不止25位了,因为这个原因run time error了两次,代码如下
 #include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#define MAX 300
int prom[MAX] = {,,,,,,,,,,,,,,,,,,,,,,,,,,,};
char A[MAX];
char B[MAX];
int ans[MAX]; int isNEnd() {
if(strcmp(A,"") == && strcmp(B,"") == ) {
return ;
}
else {
return ;
}
} int main(int argc, char const *argv[])
{
memset(A,-,sizeof(A));
memset(B,-,sizeof(B)); scanf("%s %s",A,B);
while(isNEnd()) {
int lenA = strlen(A);
int lenB = strlen(B);
int i = lenA - , j = lenB - ;
int wtemp = ;
int bitb = ;
int bitc = ;
while(i >= || j >= ) {
int i0 = i;
int j0 = j;
int numa = , numb = ;
while(i >= && A[i] != ',') {
//printf("%d\n",A[i]);
i--;
}
if(i0 >= ) {
for(int k = i + ; k <= i0; k++) {
numa = numa * + A[k] - '';
}
} while(j >= && B[j] != ',') {
//printf("%d\n",B[j]);
j--;
}
if(j0 >= ) {
for(int k = j + ; k <= j0; k++) {
numb = numb * + B[k] - '';
}
} int bit = numa + numb + bitc;
bitb = bit % prom[wtemp];
bitc = bit / prom[wtemp];
ans[wtemp] = bitb;
i--;
j--;
wtemp++;
}
if(bitc != ) {
ans[wtemp] = bitc;
wtemp++;
}
for(int i = wtemp -; i >= ; i--) {
printf("%d,",ans[i]);
}
printf("%d\n",ans[]);
scanf("%s %s",A,B);
} return ;
}

最新文章

  1. 搭建高可用的rabbitmq集群 + Mirror Queue + 使用C#驱动连接
  2. Linux LVM学习总结&mdash;&mdash;创建卷组VG
  3. Core文件作用、设置及用法
  4. MVVM架构~knockoutjs系列之文本框数符长度动态统计功能
  5. [转载]PO BO VO DTO POJO DAO概念及其作用
  6. 【动态规划】简单背包问题II
  7. 【原创】express3.4.8源码解析之路由中间件
  8. Hibernte继承映射
  9. Android 设置界面的圆角选项
  10. 常见Oracle数据库问题总结及解决办法(一)
  11. op+3g
  12. Swift 使用Extension 场景 浅析
  13. 从零开始的JS生活(二)——BOM、DOM与JS中的事件
  14. 32位linux(centos)下mongoDB的安装
  15. sourcetree跳过注册的方法
  16. Java经典编程题50道之三十四
  17. day62 中间件
  18. Java NIO之Selector(选择器)
  19. Python全栈问答小技巧_2
  20. python实现排序算法(一)——插入排序算法

热门文章

  1. 一行JS搞定快速关机
  2. Windows 10下mysql 64位 安装(mysql-5.7.11-winx64安装)
  3. ListView与ScrollView冲突的4种解决方案
  4. /etc/default/useradd
  5. 洛谷 P1774 最接近神的人_NOI导刊2010提高(02)
  6. Servlet The Filter
  7. XDU——受教了
  8. 什么是闭包(Closure)?
  9. Bootstrap-datepicker设置开始时间结束时间范围
  10. idea下使用码云插件进行git提交