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

【Codeforces 707C】Pythagorean Triples(找规律)

时间:2016-08-21 19:46:33      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:

一边长为a的直角三角形,a^2=c^2-b^2。可以发现1、4、9、16、25依次差3、5、7、9...,所以任何一条长度为奇数的边a,a^2还是奇数,那么c=a^2/2,b=c+1。我们还可以发现,1、4、9、16、25、36各项差为8、12、16、20,偶数的平方是4的倍数,那么c=a^2/4-1,b=a^2/4+1。

#include <iostream>
using namespace std;
int main() {
	long long n;
	cin>>n;
	n*=n;
	if(n>1&&n&1)
		cout<<n/2<<" "<<n/2+1;
	else if(n>4&&n%4==0)
		cout<<n/4-1<<" "<<n/4+1;
	else printf("-1");
}

  

【Codeforces 707C】Pythagorean Triples(找规律)

标签:

原文地址:http://www.cnblogs.com/flipped/p/5793229.html

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