题目传送门:http://codeforces.com/problemset/problem/484/B
题意:一个数列中找出最大的两个元素取模值
解题思路:先对数列排序,然后对每个元素,针对其倍数元素前面一个元素进行计算比较,取最大值即为答案。
AC代码:
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 200005;
int num[maxn];
int main()
{
int n;
scanf("%d", &n);
for (int i = 0; i < n; i++)
{
scanf("%d", &num[i]);
}
sort(num,num+n);
int ans = 0;
for (int i = 0; i < n; i++)
{
if (i && num[i] == num[i-1]) continue;
int k = 2 * num[i];
while (k <= num[n-1])
{
int pos = lower_bound(num,num+n,k) - num;
ans = max(ans,num[pos-1]%num[i]);
k += num[i];
}
ans = max(ans,num[n-1]%num[i]);
}
printf("%d\n",ans);
return 0;
}
本文提供了一道CodeForces竞赛题目484B的解题思路及AC代码。该题旨在从数列中找到两数相除的最大余数值,通过排序并遍历所有可能组合的方法来解决。
367

被折叠的 条评论
为什么被折叠?



