当前位置: 首页 > news >正文

南昌网站seo技术厂家重庆森林电影

南昌网站seo技术厂家,重庆森林电影,yu网站建设,新吴区推荐做网站价格互质 互质 互质 每次测试的时间限制: 3 秒 每次测试的时间限制:3 秒 每次测试的时间限制:3秒 每次测试的内存限制: 256 兆字节 每次测试的内存限制:256 兆字节 每次测试的内存限制:256兆字节 题目描述 给定…

互质 互质 互质 每次测试的时间限制: 3 秒 每次测试的时间限制:3 秒 每次测试的时间限制:3 每次测试的内存限制: 256 兆字节 每次测试的内存限制:256 兆字节 每次测试的内存限制:256兆字节


题目描述

给定一个由 n n n 个正整数 a 1 , a 2 , … , a n a_1, a_2, \dots, a_n a1,a2,,an ( 1 ≤ a i ≤ 1000 1 \le a_i \le 1000 1ai1000 ) 组成的数组。求 i + j i + j i+j 的最大值,使得 a i a_i ai a j a_j aj 互质,如果不存在这样的 i i i j j j输出 − 1 -1 1

例如,考虑数组 [ 1 , 3 , 5 , 2 , 4 , 7 , 7 ] [1, 3, 5, 2, 4, 7, 7] [1,3,5,2,4,7,7] 。由于 a 5 = 4 a_5 = 4 a5=4 a 7 = 7 a_7 = 7 a7=7 互质,所以 i + j i + j i+j 的最大值是 5 + 7 5 + 7 5+7

如果两个整数 p p p q q q 的最大公因数是 1 1 1,则这两个整数 p p p q q q 是互质。


输入

输入由多个测试用例组成。第一行包含一个整数 t t t ( 1 ≤ t ≤ 10 1 \leq t \leq 10 1t10 ) - 测试用例的数量。测试用例说明如下。

每个测试用例的第一行包含一个整数 n n n ( 2 ≤ n ≤ 2 ⋅ 1 0 5 2 \leq n \leq 2\cdot10^5 2n2105 ) - 数组的长度。

下一行包含 n n n 个空格分隔的正整数 a 1 a_1 a1 , a 2 a_2 a2 ,…, a n a_n an 1 ≤ a i ≤ 1000 1 \leq a_i \leq 1000 1ai1000 )–数组的元素。( 1 ≤ a i ≤ 1000 1 \leq a_i \leq 1000 1ai1000 ) - 数组的元素。

保证所有测试用例的 n n n 之和不超过 2 ⋅ 1 0 5 2\cdot10^5 2105


输出

对于每个测试用例,输出一个整数-- i + j i + j i+j 的最大值,使得 i i i j j j 满足 a i a_i ai a j a_j aj 为共素数的条件,或者在没有 i i i j j j 满足条件的情况下输出 − 1 -1 1


代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int INF = 0x3f3f3f3f;
const int mod = 1e9 + 7; 
const int N = 200010;int a[N];bool PD[1010][1010];int gcd(int a,int b)
{if(b==0)return a;else return gcd(b,a%b);
}int main()
{for(int i=1;i<=1000;i++)for(int j=1;j<=1000;j++)if(gcd(i,j)==1)PD[i][j]=true;int t; cin>>t;while (t--){int n; cin>>n;map<int,int>mp;for(int i=1;i<=n;i++){scanf("%d",&a[i]);mp[a[i]]=i;  //mp用来记录每种数最后出现的位置} int ans=-1;for(int i=1;i<=1000;i++)for(int j=i;j<=1000;j++)if(mp.count(i) && mp.count(j))if(PD[i][j])ans=max(ans,mp[i]+mp[j]);cout<<ans<<endl;}return 0;
}

解题思路:如果枚举数组中的每一对数的话,时间复杂度为 O ( n 2 ) O(n^2) O(n2) ,其中 n n n 2 ∗ 1 0 5 2*10^5 2105 ,该方案不可行,这绝对会TLE

这时我们可以发现 a [ i ] a[i] a[i] 的取值范围非常的小,只有 1-1000 ,所以可以尝试枚举 1-1000 中选取 2 2 2 个数的所有组合,然后判断每种组合在给定的数组中是否存在,如果存在的话再判断它们是否互质,如果互质的话找到这种组合中的两个数分别在给定的数组中最后出现的位置(这可以通过一个map来存下数组中每种值最后出现的位置)这种算法的时间复杂度为 O ( 100 0 2 ) O(1000^2) O(10002)

http://www.hkea.cn/news/561295/

相关文章:

  • 资源收费网站怎么做网站快速优化排名官网
  • 招标网哪个网站信息可靠百度站长工具网站
  • 郑州七七网站建设互联网推广公司
  • 佛山做外贸网站代理商百度收录技术
  • 公司网站建设需要什么今日热搜第一名
  • 烟台建设企业网站网站快速收录入口
  • 怎么做繁体字网站网络营销公司注册找哪家
  • 做ppt介绍网站吗网站搜索引擎优化工具
  • 深圳网站建设有没有市场百度搜索推广的五大优势
  • 网站建设好的图片百度互联网营销
  • 柳州网站制作公司seo优化什么意思
  • 网站建设做的好的公司淘宝关键词优化怎么弄
  • 手机网站用模版方象科技的企业愿景
  • 沈阳网站建设技术公司排名公司市场营销策划方案
  • 赣州网站建设怎样石家庄最新消息
  • 公司注册地址和经营地址不一致可以吗长春seo招聘
  • 好的做问卷调查的网站好推广有奖励的app平台
  • 有专业设计网站吗百度指数与百度搜索量
  • 网站的整体结构百度云网盘资源搜索引擎入口
  • 咸阳网站建设哪家专业杭州优化公司在线留言
  • 地板网站建设门户网站
  • 新增备案网站负责人人工智能培训心得体会
  • 帮境外赌场做网站是否有风险百度企业号
  • 网站换了服务器百度seo排名优化公司哪家好
  • 海南网站建设制作网络营销效果评估
  • 飞阳建设网站上海广告公司
  • 营销网站导航栏常见网站搜索排名靠前
  • 深圳市政府网站官网百度地图疫情实时动态
  • 上海建设工程咨询网 首页深圳优化排名公司
  • 杭州哪个网站建设最好做网站的网络公司