热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

3152数值选取挑战

本问题描述了一个数值选取游戏,玩家需要从给定的一系列正整数中选择一半数量的数字,目标是使这些数字的最大公约数(GCD)尽可能大。任务是计算并返回可能的最大GCD值。
数值选取挑战

在本挑战中,您将面对一系列正整数(总数为n,其中2 <= n <= 100000)。您的任务是从这组数字中选择大约一半数量的数字,即向上取整后的n/2个数,以确保这些被选中的数字的最大公约数(GCD)达到最大值。请计算并返回这个最大可能的GCD值。

输入格式

输入的第一行包含一个整数n,代表数字的数量。
第二行则包含了n个正整数。

输出格式

输出一行,仅包含一个整数,即所求的最大GCD值。

数据规模与约定

对于10%的数据,2 <= n <= 10。
对于30%的数据,2 <= n <= 300。
对于60%的数据,2 <= n <= 5000。
对于100%的数据,2 <= n <= 100000。

示例

输入示例1:
6
6 2 3 4 5 6
输出示例1:
3

输入示例2:
5
5 5 6 10 15
输出示例2:
5

以下是解决此问题的一种方法的C++实现代码:

#include
#include
#include
#include
#include
#define maxn 1000000
#define maxt 10
using namespace std;
typedef long long ll;
int n;
ll a[maxn+5];
ll gcd(ll a, ll b) {
return b == 0 ? a : gcd(b, a % b);
}
int random(int l, int r) {
return (long long)rand() * rand() % (r - l + 1) + l;
}
int sz = 0;
ll d[maxn+5];
int cnt[maxn+5];
void divide(ll x) {
sz = 0;
for (ll i = 1; i * i <= x; i++) {
if (x % i == 0) {
d[++sz] = i;
if (x / i != i) d[++sz] = x / i;
}
}
}
int main() {
scanf("%d", &n);
for (int i = 1; i <= n; i++) scanf("%I64d", &a[i]);
ll ans = 0;
for (int cas = 1; cas <= maxt; cas++) {
ll x = a[random(1, n)];
divide(x);
sort(d + 1, d + sz + 1);
for (int i = 1; i <= sz; i++) cnt[i] = 0;
for (int i = 1; i <= n; i++) {
int pos = lower_bound(d + 1, d + 1 + sz, gcd(a[i], x)) - d;
cnt[pos]++;
}
for (int i = 1; i <= sz; i++) {
for (int j = i + 1; j <= sz; j++) {
if (d[j] % d[i] == 0) cnt[i] += cnt[j];
}
}
for (int i = sz; i >= 1; i--) {
if (cnt[i] * 2 >= n) {
ans = max(ans, d[i]);
break;
}
}
}
printf("%I64d\n", ans);
return 0;
}

推荐阅读
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 本文基于刘洪波老师的《英文词根词缀精讲》,深入探讨了多个重要词根词缀的起源及其相关词汇,帮助读者更好地理解和记忆英语单词。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
author-avatar
aihyuksj_967
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有