社区讨论
求助
P8814[CSP-J 2022] 解密参与者 2已保存回复 4
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 4 条
- 当前快照
- 1 份
- 快照标识符
- @lo7lha6g
- 此快照首次捕获于
- 2023/10/27 03:46 2 年前
- 此快照最后确认于
- 2023/10/27 03:46 2 年前
官网爆0,民间70pts
CPP#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int main()
{
//freopen("decode.in", "r", stdin);
//freopen("decode.out", "w", stdout);
long long int k;
cin >> k;
while(k --)
{
long long int n, e, d;
cin >> n >> e >> d;
long long int b = n - e * d + 2;
if(b * b - 4 * n < 0)
{
cout << "NO" << endl;
continue;
}
if(sqrt(b * b - 4 * n) * sqrt(b * b - 4 * n) != b * b - 4 * n)
{
cout << "NO" << endl;
continue;
}
long long int tmp = sqrt(b * b - 4 * n);
long long int q = (-b + tmp) / -2;
long long int q2 = (-b - tmp) / -2;
if(q <= 0 && q2 <= 0)
{
cout << "NO" << endl;
continue;
}
if(int(n / q) * q != n || q <= 0 || q == 1)
{
if(int(n / q2) * q2 != n || q2 <= 0 || q2 == 1)
{
cout << "NO" << endl;
continue;
}
cout << min(q2, n / q2) << ' ' << max(q2, n / q2) << endl;
}
else cout << min(q, n / q) << ' ' << max(q, n / q) << endl;
}
return 0;
}
回复
共 4 条回复,欢迎继续交流。
正在加载回复...