3338 蓝桥杯 wyz的数组IV 简单

3338 蓝桥杯 wyz的数组IV 简单

复制代码
//C++风格解法1,通过率50%
#include<bits/stdc++.h>

int main(){
	std::ios::sync_with_stdio(false);std::cin.tie(nullptr);std::cout.tie(nullptr);
	int n;	std::cin >> n;
	int ans = 0;
	std::vector<int>a(n);
	for(auto &x: a)std::cin >> x;
	for(int i = 0; i < n; i++){
		for(int j = i + 1; j < n; j++){
			if(std::gcd(a[i], a[j]) == 2)ans = std::max(ans, i + j + 2);  //gcd()
            // i + j + 2 的原因是:下标从0,但第几个从 1 开始,两个数 + 2
			// C++中,std::__gcd(x, y)(C98) 和 std::gcd(x,y)(C++17) 直接求 x,y 的最大公约数
      // n * n, n = 10^5, n * n = 10^(10),1s一般是 2 * 10^8
    }
	}
	std::cout << ans <<'\n';
	
	return 0;
}

//C风格解法2,通过率100%
#include<bits/stdc++.h>

const int N = 1e3 + 1;

int mx[N]; // mx_i 表示的 i 这个数值的数在原数组的最大下标,桶

int main(){
	int n;    scanf("%d", &n); // 读入 n
  int ans = 0;
  for(int i = 1; i <= n; i++){    
    int x;    scanf("%d", &x); // 输入 a_i
    
    if(x == 2){
      if(mx[2] != 0)ans = std::max(ans, mx[2] + i);
    }
    mx[x] = std::max(mx[x], i);
  }
	
  for(int i = 2; i <= 1000; i++){ // 枚举的是值,而不是下标,10^3
    for(int j = i + 1; j <= 1000; j++){ // 枚举的是值,而不是下标,10^3
      if(mx[i] == 0 || mx[j] == 0)continue; // 如果 i 或 j 没有出现,就 contine
      if(std::gcd(i,j) != 2)continue;
      ans = std::max(ans, mx[i] + mx[j]);
    }
  }
  printf("%d\n", ans);
	return 0;
}

reference:

【C++】_gcd(x,y)函数∑ y∈c gcd(x,y)-CSDN博客

最大公约数 ------ Greatest Common Divisor(GCD) - 知乎 (zhihu.com)
​​​​​​
[详解-vector] C++必知必会 vector常用各种操作解析 - 知乎 (zhihu.com)

相关推荐
钰珠AIOT7 分钟前
什么是句柄,有什么用?适用于什么场景?
c语言·c++
众少成多积小致巨27 分钟前
Android 初始化语言入门
android·linux·c++
yangtuoni29 分钟前
vscode调试C++ python相关配置
c++·vscode·python
wuyoula39 分钟前
尹之盾企业版网络验证
服务器·开发语言·javascript·c++·人工智能·ui·c#
hi_ro_a1 小时前
C++ 手撕 STL 底层:红黑树封装 mymap/myset
数据结构·c++·算法
小卓(friendhan2005)1 小时前
基于Qt的音乐播放器项目
数据库·c++·qt
tankeven1 小时前
贪心算法(Greedy Algorithm)详解:从理论到C++实践
c++·算法
Hesionberger1 小时前
LeetCode72.编辑距离(多维动态规划)
java·开发语言·c++·python·算法
郝学胜-神的一滴1 小时前
从底层看透Linux高性能服务器:epoll自定义封装与超时清理实战
linux·服务器·c++·网络协议·tcp/ip·unix
小张的博客之旅1 小时前
2026年第十七届蓝桥杯网络安全赛项WriteUp
安全·web安全·蓝桥杯