HDU 4554

来源:互联网 发布:手机怎么链接电脑网络 编辑:程序博客网 时间:2024/06/16 09:38

叛逆的小明

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)
Total Submission(s): 758    Accepted Submission(s): 518


Problem Description
叛逆期的小明什么都喜欢反着做,连看数字也是如此(负号除外),比如:
小明会把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是小数的情况。
 

Output
输出共T行,每行输出两个整数s t,之间用一个空格分开,其中s表示小明将得到的a+b答案,t表示小明将得到的a-b答案。
 

Sample Input
320 67 7-100 -140
 

Sample Output
38 247 7-19 -23
 

Source
2013金山西山居创意游戏程序挑战赛——初赛(4)

 

在讨论区看到一哥们写的这个。

 

附上代码。。

#include <stdio.h>int gaibian(int a)  {    int flag=0;int c=0;if(a<0)    //小于0先变正。a=-a,flag=1;while(a)    {c=c*10+a%10;a/=10;   //将一个数倒过来。}if(flag)c=-c;  //再变负。return c;}int main(){int n;scanf("%d",&n);while(n--){int a,b,x,y;scanf("%d%d",&a,&b);         x=(a+b)/2;  //简单二元一次方程求解后  y=(a-b)/2; x=gaibian(x);  //改变x,y的值。 y=gaibian(y); printf("%d %d\n",x+y,x-y);  //得到最终的答案。} return 0;}


 

0 0
原创粉丝点击