首页 > 代码库 > 九度OJ 1089 数字反转
九度OJ 1089 数字反转
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:2591
解决:1425
- 题目描述:
12翻一下是21,34翻一下是43,12+34是46,46翻一下是64,现在又任意两个正整数,问他们两个数反转的和是否等于两个数的和的反转。
- 输入:
第一行一个正整数表示测试数据的个数n。
只有n行,每行两个正整数a和b(0<a,b<=10000)。
- 输出:
如果满足题目的要求输出a+b的值,否则输出NO。
- 样例输入:
2 12 34 99 1
- 样例输出:
46 NO
#include<stdio.h> #include<string.h> #include<stdlib.h> char a[10]; char b[10]; char c[10]; int a1,b1,s1,a2,b2,s2; void reverse(char *a) { int len=strlen(a); for(int i=0,j=len-1;i<j;++i,--j) { int t=a[i]; a[i]=a[j]; a[j]=t; } } int main(int argc, char *argv[]) { int n; while(~scanf("%d",&n)) { for(int i=0;i<n;++i) { scanf("%s%s",a,b); a1=atoi(a); b1=atoi(b); s1=a1+b1;//和 reverse(a); reverse(b); a2=atoi(a); b2=atoi(b); s2=a2+b2;//反转的和 int j=0; while(s1) { c[j++]=s1%10+'0'; s1/=10; } c[j]='\0';//和的反转 s1=atoi(c); if(s1==s2) { reverse(c); printf("%s\n",c); } else printf("NO\n"); } } return 0; } /************************************************************** Problem: 1089 User: kirchhoff Language: C Result: Accepted Time:0 ms Memory:912 kb ****************************************************************/
九度OJ 1089 数字反转
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。