【二分】Pythagorean Triples—CF1487D

Pythagorean Triples---CF1487D

思路

联立 a 2 = b + c 2 a^2 = b + c^2 a2=b+c2、 a 2 + b 2 = c 2 a^2 + b^2 = c^2 a2+b2=c2 得:
a 2 = 2 ∗ c − 1 a^2 = 2 * c - 1 a2=2∗c−1、 b = c − 1 b = c - 1 b=c−1。

对于一个固定的 a a a, b b b、 c c c 的值都是固定的,只要满足 a ≤ b a\le b a≤b 和 c ≤ n c\le n c≤n 即可。

使用二分可以求出对应的 c c c 的值满足条件的 a a a 的取值范围,另外要排除 a = 1 , 2 a = 1, 2 a=1,2 这两个值,因为这时候 a > b a > b a>b。

C o d e Code Code

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define sz(a) ((int)a.size())
#define all(a) a.begin(), a.end()
using namespace std;
using PII = pair<int, int>;
using i128 = __int128;
const int N = 2e5 + 10;

int n;

// c的值是否符合条件(先不考虑奇数这个条件)
int judge(int a) {
	if ((a * a + 1) / 2 <= n
		&& a <=(a * a + 1) / 2 - 1) {
		return 1;
	}
	return 0;
}

void solve() {
	cin >> n;
	cout << "       ";
	
	if (n <= 2) {
		cout << 0 << "\n";
		return;
	}
	
	// 二分求a的最大值(先不考虑得到的c是否是整数)
	int l = 3, r = n;
	while (l < r) {
		int mid = (l + r + 1) / 2;
		if (judge(mid)) {
			l = mid;
		} else {
			r = mid - 1;
		}
	}
	if (l % 2 == 0) {
		l --;
	}
	
	// 现在满足条件的a的取值范围是[3, l]中的所有奇数
	if (judge(l)) {
		cout << l / 2 << "\n";
	} else {
		cout << "0\n";
	}
}

signed main() {
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	int T = 1;
	cin >> T; cin.get();
	while (T --) solve();
	return 0;
}
相关推荐
Dovis(誓平步青云)3 分钟前
基于探索C++特殊容器类型:容器适配器+底层实现原理
开发语言·c++·queue·适配器·stack
Gyoku Mint36 分钟前
深度学习×第4卷:Pytorch实战——她第一次用张量去拟合你的轨迹
人工智能·pytorch·python·深度学习·神经网络·算法·聚类
葫三生2 小时前
如何评价《论三生原理》在科技界的地位?
人工智能·算法·机器学习·数学建模·量子计算
pipip.2 小时前
UDP————套接字socket
linux·网络·c++·网络协议·udp
拓端研究室4 小时前
视频讲解:门槛效应模型Threshold Effect分析数字金融指数与消费结构数据
前端·算法
随缘而动,随遇而安6 小时前
第八十八篇 大数据中的递归算法:从俄罗斯套娃到分布式计算的奇妙之旅
大数据·数据结构·算法
孞㐑¥6 小时前
Linux之Socket 编程 UDP
linux·服务器·c++·经验分享·笔记·网络协议·udp
IT古董6 小时前
【第二章:机器学习与神经网络概述】03.类算法理论与实践-(3)决策树分类器
神经网络·算法·机器学习
水木兰亭9 小时前
数据结构之——树及树的存储
数据结构·c++·学习·算法
Jess0710 小时前
插入排序的简单介绍
数据结构·算法·排序算法