码迷,mamicode.com
首页 > 其他好文 > 详细

杭电ACM1194——Beat the Spread!

时间:2015-05-02 20:46:48      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:acm   杭电   

简单的数学题目,就是解方程。

不过需要注意的是,解出来的两个解没有负数。

输入m和n,方程1:x + y = m;方程2:| x - y | = n;

x = (n + m)/ 2; y = (-n + m)/ 2;

注意:n + m和m - n 必须是偶数!~~做个判断就OK了。

AC的代码:

#include <iostream>
using namespace std;

int main()
{
	int t, a, b;
	cin >> t;
	while(t--)
	{
		cin >> a >> b;
		if((b + a) % 2 && (-b + a) % 2)
		{
			cout << "impossible" << endl;
			continue;
		}
		int ans_1 = (b + a) / 2;
		int ans_2 = (-b + a) / 2;
		if(ans_1 > 0 && (b + a) % 2 == 0 && a - ans_1 > 0)
			cout << ans_1 << ' ' << a - ans_1 << endl;
		else if(ans_2 > 0 && (-b + a) % 2 == 0 && a - ans_2 > 0)
			cout << ans_2 << ' ' << a - ans_2 << endl;
		else
			cout << "impossible" << endl;
	}
	return 0;
}


杭电ACM1194——Beat the Spread!

标签:acm   杭电   

原文地址:http://blog.csdn.net/qq_25425023/article/details/45441759

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!