Codeforces Round #368 (Div. 2)(C. Pythagorean Triples 勾股数规律)

16 篇文章 0 订阅
13 篇文章 0 订阅

题目链接

给出一个数,输出2个数,使得这三个数是勾股数

形如2n,n^2-1,n^2+1可以组合成勾股数,这是偶数的情况
奇数的时候看个例子
3, 4 , 5 | 4 = (1+3) * 1
5,12,13 | 12 = (1+5)*2
7,24,25 | 24 = (1+7)*3
9,40,41 | 40 = (1+9)*4

第二列数就是第一列数在以3为首项的等差数列中的位置*(该数+1)

#include<bits/stdc++.h>
using namespace std;
#define cl(a,b) memset(a,b,sizeof(a))
#define fastIO ios::sync_with_stdio(false);cin.tie(0);
#define LL long long
#define pb push_back
#define gcd __gcd

#define For(i,j,k) for(int i=(j);i<k;i++)
#define lowbit(i) (i&(-i))
#define _(x) printf("%d\n",x)


const int maxn = 3e6+10;
const int inf  = 1 << 28;
LL mx = 1e18;
bool flag = false;
void out(LL a,LL b) {
    if(a>mx||b>mx||a<=0||b<=0) {
        //printf("-1\n");
        return;
    } else {
        printf("%lld %lld\n",a,b);
        flag = true;
    }
}

void work(LL n) {
    flag = false;
    if(n%3==0) {
        out(n/3*4,n/3*5);
    }
    if(flag) return ;
    if(n%4==0) {
        out(n/4*3,n/4*5);
    }
    if(flag) return ;
    if(n%5==0) {
        out(n/5*3,n/5*4);
    }
    if(flag) return ;
    if(n%2==1) {
        LL t = (n-1)/2;
        LL a = t*(n+1);
        LL b = a+1;
        out(a,b);
    }
    if(flag) return ;
    if(n%2==0){
        LL t = n/2;
        LL a = t*t-1;
        LL b = t*t+1;
        out(a,b);
    }
    if(flag) return ;
    puts("-1");

}

int main() {
    LL n;
    scanf("%lld",&n);
    work(n);

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值