刚刚搞acm每几个月,今天参加了杭电acm上西山居举行的一个比赛,没想到竟然入围了。只做对了一个题。杭电4554叛逆的小明。
叛逆的小明
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)
Total Submission(s): 77 Accepted Submission(s): 57
Problem Description
叛逆期的小明什么都喜欢反着做,连看数字也是如此(负号除外),比如:
小明会把1234它看成4321;把-1234看成-4321;把230看成032 (032=32);把-230看成-032(-032=-32)。
现在,小明做了一些a+b和a-b的题目(a, b为整数且不含前导0),如果给你这些题目正确的答案,你能猜出小明会做得到什么答案吗?
小明会把1234它看成4321;把-1234看成-4321;把230看成032 (032=32);把-230看成-032(-032=-32)。
现在,小明做了一些a+b和a-b的题目(a, b为整数且不含前导0),如果给你这些题目正确的答案,你能猜出小明会做得到什么答案吗?
Input
输入第一行为一个正整数T(T<=10000),表示小明共做了T道题。
接下来T行,每行是两个整数x,y(-1000000<=x, y<=1000000), x表示a+b的正确答案,y表示a-b的正确答案。
输入保证合法,且不需考虑a或b是小数的情况。
接下来T行,每行是两个整数x,y(-1000000<=x, y<=1000000), x表示a+b的正确答案,y表示a-b的正确答案。
输入保证合法,且不需考虑a或b是小数的情况。
Output
输出共T行,每行输出两个整数s t,之间用一个空格分开,其中s表示小明将得到的a+b答案,t表示小明将得到的a-b答案。
Sample Input
3 20 6 7 7 -100 -140
Sample Output
38 24 7 7 -19 -23
Source
Recommend
liuyiding
#include<stdio.h>
int main()
{
long a,b;
int n,c,d;
scanf("%d",&n);
while(n--)
{
scanf("%d%d",&c,&d);
a=(c+d)/2;
b=(c-d)/2;
if(a==0) a=a;
else if(a>0&&a<10) a=a;
else if(a>10&&a<100) a=(a%10)*10 + a/10;
else if(a>100&&a<1000) a=(a%10)*100 + (a/10)%10*10 + a/100;
else if(a>1000&&a<10000) a=(a%10)*1000 + (a/10)%10*100 + (a/100)%10*10 + a/1000;
else if(a>10000&&a<100000) a=(a%10)*10000 + (a/10)%10*1000 + (a/100)%10*100 + (a/1000)%10*10 + a/10000;
else if(a>100000&&a<1000000) a=(a%10)*100000 + (a/10)%10*10000 + (a/100)%10*1000+ (a/1000)%10*100 +(a/10000)%10*10 +a/100000;
else if(a==10||a==100 || a==1000 || a==10000||a==100000||a==1000000) a=1;
if(a<0)
{
a=-a;
if(a>0&&a<10) a=a;
else if(a>10&&a<100) a=(a%10)*10 + a/10;
else if(a>100&&a<1000) a=(a%10)*100 + (a/10)%10*10 + a/100;
else if(a>1000&&a<10000) a=(a%10)*1000 + (a/10)%10*100 + (a/100)%10*10 + a/1000;
else if(a>10000&&a<100000) a=(a%10)*10000 + (a/10)%10*1000 + (a/100)%10*100 + (a/1000)%10*10 + a/10000;
else if(a>100000&&a<1000000) a=(a%10)*100000 + (a/10)%10*10000 + (a/100)%10*1000+ (a/1000)%10*100 +(a/10000)%10*10 +a/100000;
else if(a==10||a==100 || a==1000 || a==10000||a==100000||a==1000000) a=1;
a=-a;
}
if(b==0) b=b;
else if(b>0&&b<10) b=b;
else if(b>10&&b<100) b=(b%10)*10 + b/10;
else if(b>100&&b<1000) b=(b%10)*100 + (b/10)%10*10 + b/100;
else if(b>1000&&b<10000) b=(b%10)*1000 + (b/10)%10*100 + (b/100)%10*10 + b/1000;
else if(b>10000&&b<100000) b=(b%10)*10000 + (b/10)%10*1000 + (b/100)%10*100 + (b/1000)%10*10 + b/10000;
else if(b>100000&&b<1000000) b=(b%10)*100000 + (b/10)%10*10000 + (b/100)%10*1000+ (b/1000)%10*100 +(b/10000)%10*10 +b/100000;
else if(b==10||b==100 || b==1000 || b==10000||b==100000||b==1000000) b=1;
if(b<0)
{
b=-b;
if(b>0&&b<10) b=b;
else if(b>10&&b<100) b=(b%10)*10 + b/10;
else if(b>100&&b<1000) b=(b%10)*100 + (b/10)%10*10 + b/100;
else if(b>1000&&b<10000) b=(b%10)*1000 + (b/10)%10*100 + (b/100)%10*10 + b/1000;
else if(b>10000&&b<100000) b=(b%10)*10000 + (b/10)%10*1000 + (b/100)%10*100 + (b/1000)%10*10 + b/10000;
else if(b>100000&&b<1000000) b=(b%10)*100000 + (b/10)%10*10000 + (b/100)%10*1000+ (b/1000)%10*100 +(b/10000)%10*10 +b/100000;
else if(b==10||b==100 || b==1000 || b==10000||b==100000||b==1000000) b=1;
b=-b;
}
printf("%d %d\n",a+b,a-b);
}
return 0;
}
这是我的源码,比赛时时间有限,本人有是新手,就没有去考虑神马算法,神马高深的问题,就只能分情况讨论,没想到到最后还真给整出来了,代码比较水 将就这看吧。
欢迎大家积极留言,欢迎喜欢acm的战友 以及喜欢编程的同志 同学 加我qq:827552788