上海市计算机学会竞赛平台2024年1月月赛乙组序列最大公约数(二)

题目描述

给定 𝑛n 个正整数𝑎1,𝑎2,...,𝑎𝑛a1​,a2​,...,an​,你可以至多修改其中一个数字,使这 𝑛n 个数字的最大公约数尽可能的大。

请问修改后可能的最大公约数的值。

输入格式

输入共两行,

第一行:一个正整数 𝑛n

第二行:𝑛n 个正整数 𝑎1,𝑎2,...,𝑎𝑛a1​,a2​,...,an​

输出格式

输出至多修改一个数字的情况下,可能达到的最大公约数的值

数据范围
  • 30%30% 的数据,1≤𝑛≤1031≤n≤103
  • 60%60% 的数据,1≤𝑛≤1041≤n≤104
  • 100%100% 的数据,1≤𝑛,≤1051≤n,≤105 ,1≤𝑎𝑖≤1091≤ai≤109
样例数据

输入:

3

24 28 36

输出:

12

说明:

修改28,改成12即可

输入:

3

10 10 10

输出:

10

详见代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n;
int a[100005];
int q[100005];
int h[100005];
int gcd(int x,int y){
    if(x%y==0) return y;
    return gcd(y,x%y);
}
int main() {
    cin>>n;
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }
    q[1]=a[1];
    for(int i=2;i<=n;i++){
        q[i]=gcd(q[i-1],a[i]);
    }
    h[n]=a[n];
    for(int i=n-1;i>=1;i--){
        h[i]=gcd(h[i+1],a[i]);
    }
    int ans=max(h[2],q[n-1]);
    for(int i=2;i<n;i++){
        ans=max(ans,gcd(q[i-1],h[i+1]));
    }
    cout<<ans;
相关推荐
程序员Xu1 小时前
【LeetCode热题100道笔记】二叉树的右视图
笔记·算法·leetcode
笑脸惹桃花1 小时前
50系显卡训练深度学习YOLO等算法报错的解决方法
深度学习·算法·yolo·torch·cuda
阿维的博客日记2 小时前
LeetCode 48 - 旋转图像算法详解(全网最优雅的Java算法
算法·leetcode
GEO_YScsn2 小时前
Rust 的生命周期与借用检查:安全性深度保障的基石
网络·算法
程序员Xu2 小时前
【LeetCode热题100道笔记】二叉搜索树中第 K 小的元素
笔记·算法·leetcode
THMAIL3 小时前
机器学习从入门到精通 - 数据预处理实战秘籍:清洗、转换与特征工程入门
人工智能·python·算法·机器学习·数据挖掘·逻辑回归
Kevinhbr3 小时前
CSP-J/S IS COMING
数据结构·c++·算法
Armyyyyy丶4 小时前
Redis底层实现原理之五大基础结构
数据结构·redis·缓存
蕓晨4 小时前
set的插入和pair的用法
c++·算法
THMAIL4 小时前
深度学习从入门到精通 - AutoML与神经网络搜索(NAS):自动化模型设计未来
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归