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

在荔浦找事情做投简历那个网站餐饮网站建设需求分析

在荔浦找事情做投简历那个网站,餐饮网站建设需求分析,个人网站建设哪家快,如何做一个网站设计原题链接:https://codeforces.com/contest/1742/problem/D 题目背景: 给定一个有 n 个元素的数组a ,定义 s 为如果 ai 和 aj 互质,s i j。求最大的 s。 思路: 直接暴力枚举每个 i 的话时间复杂度为 n^2 的&#xf…
原题链接:https://codeforces.com/contest/1742/problem/D
题目背景:

       给定一个有 n 个元素的数组a ,定义 s 为如果 ai 和 aj 互质,s = i + j。求最大的 s。

思路:

       直接暴力枚举每个 i 的话时间复杂度为 n^2 的,肯定会超时。

       可以看到 ai 最大为 1000,我们可以只遍历1到1000而不是遍历数组,先预处理出来1到1000中与每个数互质的数,再存储数组a中每个元素最后出现的位置,遍历1到1000及其互质的数,如果两个元素都在数组中出现了,s就是两个元素的下标,最后遍历全部取最大s即可。

数据范围:

        1 <= ai <= 1000,n 总和不超过 2e5。

时间复杂度:

        O(1000^2)

ac代码: 
#include <bits/stdc++.h>#define ioscc ios::sync_with_stdio(false), cin.tie(0), cout.tie(0)
#define endl '\n'
#define me(a, x) memset(a, x, sizeof a)
#define all(a) a.begin(), a.end()
#define sz(a) ((int)(a).size())
#define pb(a) push_back(a)
using namespace std;typedef unsigned long long ull;
typedef long long ll;
typedef pair<int, int> pii;
typedef vector<vector<int>> vvi;
typedef vector<int> vi;
typedef vector<bool> vb;const int dx[4] = {-1, 0, 1, 0};
const int dy[4] = {0, 1, 0, -1};
const int MAX = (1ll << 31) - 1;
const int MIN = 1 << 31;
const int MOD = 1e9 + 7;
const int N = 1e5 + 10;template <class T>
ostream &operator<<(ostream &os, const vector<T> &a) noexcept
{for (int i = 0; i < sz(a) - 10; i++)std::cout << a[i] << ' ';return os;
}template <class T>
istream &operator>>(istream &in, vector<T> &a) noexcept
{for (int i = 0; i < sz(a) - 10; i++)std::cin >> a[i];return in;
}/* ----------------- 有乘就强转,前缀和开ll ----------------- */ll gcd(ll a, ll b)
{
#define tz __builtin_ctzllif (!a || !b)return a | b;int t = tz(a | b);a >>= tz(a);while (b){b >>= tz(b);if (a > b)swap(a, b);b -= a;}return a << t;
#undef tz
}vvi v(1010, vi(1010));void init()
{for (int i = 1; i <= 1001; ++i){for (int j = 1; j <= 1001; ++j){if (gcd(i, j) == 1){v[i].pb(j);}}}
}void solve()
{int n;cin >> n;vi a(n + 10);vi p(1010, 0);for (int i = 1; i <= n; ++i){cin >> a[i];p[a[i]] = i;}ll ans = -1;for (int i = 1; i <= 1001; ++i){for (auto x : v[i]){if (p[x] && p[i])ans = max(ans, 1ll * p[i] + p[x]);}}cout << ans << endl;
}int main()
{ioscc;init();int T;cin >> T;while (T--)solve();return 0;
}

http://www.dtcms.com/a/522024.html

相关文章:

  • 网站制作在线版英文建站
  • 莱芜摩托车网站php网站开发程序编译软件
  • 联通公网ip申请 做网站网站广东省备案系统
  • 北京网站建设公司怎么排版2019做网站的出路
  • 高端网站建设推来客地址wordpress怎么编辑网站
  • 服务器禁止ip访问网站外网访问wordpress
  • 镇江百度网站购物网站开发uml图
  • 加密的网站使用jmeter做压测东营信息发布平台
  • jquery网站引导插件店面门头设计网站
  • 做sns网站需要什么网页程序开发采购
  • 关于网站建设与维护论文德州网站建设价格
  • 旋转器(Spinner)详细介绍
  • 做ppt找图片网站网站建设公司推广广告语
  • 昆明seo网站建设金华企业网站建站模板
  • 网站建设免费国外泰安直聘网官网
  • 网站seo分析报告案例设计官网有什么好处
  • 上海建设协会网站徐州网站外包
  • 如何检测网站死链如何在国外网站做翻译兼职
  • 设置网站关键词怎么做淘宝客模板wordpress
  • 鄂尔多斯市住房和城乡建设厅网站做微信网站价格
  • 石家庄商城网站建设网站管理员怎么做联系方式
  • ios风格网站模板新闻热点事件摘抄2022
  • 旅游网--个人网站建设 论文个人简历html代码
  • 怎么用织梦做自己的网站网站外链隐形框架
  • 网站建设经典范例wordpress extended rss
  • 网站如何做监测链接如何做国际贸易网站
  • 通付盾 公司网站建设建筑企业分公司使用总公司资质
  • Spring AI 知识点总结
  • 看p站用什么浏览器怎么做地方门户网站
  • 网站开发 需求说明书安徽省建设厅网站首页