题目:
|
|
思路:
这是一道思维题,构造算法
在这里,题目意思是 n 是 k 个元素的总和,每个元素它们的奇偶性一致,并且它们除以2余数相同
这里我们 每个元素除以 2 余数相同,就是奇偶性一致,又因为 它们当中元素肯定跟我们的 n 因子成倍数关系,所以我们可以从 分解因子 进行突破,构造出来就可以了
代码详解如下:
#include <iostream>
#define endl '\n'
#define YES puts("YES");
#define NO puts("NO");
using namespace std;
int n, k;
int other; // 为 k - 1 个因子元素
int last; // n - (k - 1) * other 为 k 最后一个元素
// 这里是构造得来的函数
inline bool Finds(int &i)
{
other = (k - 1) * i; // 我们找出符合 k - 1 个因子
last = n - other;
// 并判断 n - (k - 1 个因子) 后它们是否和 该因子成倍数关系
// 并且它们的 除以 2 的余数是否相同
// 是则输出答案即可
if (other < n && last % i == 0 && last % 2 == i % 2)
{
YES;
cout << last << ' ';
k--;
while (k--)
cout << i << ' ';
putchar('\n');
return true;
}
return false;
}
inline void solve()
{
cin >> n >> k;
// 分解 n 的因子,因为我们总和 n 个 ai 中肯定有 n 的因子
// 所以我们从 n 的因子中突破,对因子 构造即可获得答案
for (int i = 1; i * i <= n; ++i)
{
if (n % i == 0)
{
if (Finds(i))
return ;
if (i * i != n)
{
int tem = n / i;
if (Finds(tem))
return ;
}
}
}
NO;
}
int main()
{
int _t;
cin >> _t;
while (_t--)
{
solve();
}
return 0;
}
最后提交: