最小因子是 2 2 2 ,所以答案就是 n 2 \frac{n}{2} 2n 。
int n, m, k;
int main()
{
int T;
sd(T);
while (T--)
{
sd(n);
pd(n / 2);
}
return 0;
}
没有要求最后得到的 G C D GCD GCD 是最大的,那么就让奇数+奇数,偶数+偶数,这样得到的 G C D GCD GCD 最小也是 2 2 2 。
const int N = 2e5 + 50;
int n, m, k;
int a[N];
vector<PII> ans;
int main()
{
int T;
sd(T);
while (T--)
{
sd(n);
vector<int> odd, even;
rep(i, 1, 2 * n)
{
sd(a[i]);
if (a[i] & 1)
odd.pb(i);
else
even.pb(i);
}
int leno = odd.size();
int lene = even.size();
ans.clear();
rep(i, 0, leno - 1)
{
if (i + 1 <= leno - 1)
ans.pb(PII(odd[i], odd[i + 1]));
i++;
}
rep(i, 0, lene - 1)
{
if (i + 1 <= lene - 1)
ans.pb(PII(even[i], even[i + 1]));
i++;
}
rep(i, 0, n - 2)
pdd(ans[i].fi, ans[i].se);
}
return 0;
}
const int N = 2e5 + 50;
int n, m, k;
int main()
{
int T;
sd(T);
while (T--)
{
sd(n);
bool flag;
if (n == 1)
flag = 0;
else if (n & 1 || n == 2)
flag = 1;
else
{
int cnt = 0;
while (n % 2 == 0)
n /= 2, cnt++;
if (n == 1 || (cnt == 1 && judge(n)))//判断n是不是素数
flag = 0;
else
flag = 1;
}
if (flag)
puts("Ashishgup");
else
puts("FastestFinger");
}
return 0;
}
二分答案 ,排序后,对于每次二分的答案判断选取 k k k 个数是是否可以满足选取的符合题意条件。
const int N = 5e5 + 50;
int a[N];
int n, k;
bool check(int x)
{
int pos = 0;
bool flag = true, flag2 = true;
rep(i, 1, k)
{
if (i & 1)
{
if (pos == n)
flag = false;//选不够
pos++;
}
else
{
if (pos == n)//选不够
flag = false;
pos++;
while (a[pos] > x && pos < n)//选取偶数位置
pos++;
if (a[pos] > x)
{
flag = false;
break;
}
}
}
pos = 0;
rep(i, 1, k)
{
if (i % 2 == 0)
{
if (pos == n)
flag2 = false;
pos++;
}
else
{
if (pos == n)
flag2 = false;
pos++;
while (a[pos] > x && pos < n)
pos++;
if (a[pos] > x)
{
flag2 = false;
break;
}
}
}
if (flag || flag2)
return true;
else
return false;
}
int main()
{
sdd(n, k);
vector<int> v;
rep(i, 1, n)
{
sd(a[i]);
v.pb(a[i]);
}
sort(all(v));
int l = 0, r = n - 1;
int ans = 0;
while (r >= l)
{
int mid = l + r >> 1;
if (check(v[mid]))
{
r = mid - 1;
ans = v[mid];
}
else
l = mid + 1;
}
pd(ans);
return 0;
}