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

网络空间 网站 域名专业的网站开发公司电话

网络空间 网站 域名,专业的网站开发公司电话,字幕组 主页 wordpress,有没有一些网站可以做问卷本题链接:登录—专业IT笔试面试备考平台_牛客网 题目: 样例1: 输入 4 5 9 2 3 4 5 输出 YES 0 0 1 1 样例2: 输入 3 3 4 1 2 4 输出 NO 思路: 这道题关键点在于。 当集合中有一个元素均存在于集合 A 和集合 B 的时…

本题链接:登录—专业IT笔试面试备考平台_牛客网

题目:

样例1:

输入
4 5 9
2 3 4 5

输出
YES
0 0 1 1

 样例2:

输入
3 3 4
1 2 4

输出
NO

思路:

        这道题关键点在于。

        当集合中有一个元素均存在于集合 A 和集合 B 的时候是 NO。

        并且 P_{i} 的范围是 1 ~ 1e9 所以,当 P_{i} >= max(a,b) 的时候也是 NO。

        我们同时可以指定一个 元素范围外的 一个元素作为 根元素集合 A,B

        其次,我们可以将 下标 作为对应的每一个元素,最后进行合并求结果即可。

代码详解如下:

#include <iostream>
#include <vector>
#include <unordered_map>
#define umap unordered_map
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;umap<int,int>pos;	// 存储元素对应的下标// 存储元素集合,至于为什么也用 umap ,由于 Pi 的数据范围上限是 1e9
// 我们要将数组无法开辟这么大,所以我们只能弄个映射 来存储对应的 A,B 根元素
umap<int,int>father;	// 并查集查找函数
inline int Finds(int x)
{int t = x;	// 记录其实查找结点while(x != father[x]) x = father[x];	// 开始查找father[t] = x;	// 路径压缩查找return x;	// 返回结果
}// 并查集合并操作
inline void Union(int a,int b)
{a = Finds(a),b = Finds(b);	// 查找对应根节点father[a] = b;	// 合并对应根节点
}inline void solve()
{int n,a,b;cin >> n >> a >> b;int maxs = max(a,b);	// 获取对应 a b 最大值int A = maxs + 1;	// 根据对应的最大值,赋值一个元素范围外的元素作为 集合 A 的根节点int B = maxs + 2;	// 根据对应的最大值,赋值一个元素范围外的元素并且不同于集合A的根元素的元素作为 集合 B 的根节点father[A] = A,father[B] = B;	// 集合根节点初始化vector<int>v(n + 2,0);	// 存储对应元素for(int i = 1;i <= n;++i){cin >> v[i];if(v[i] >= maxs)	// 如果存在 元素 大于 a 和 b ,那么放不了 任意集合,无解输出 NO{cout << "NO" << endl;return ;}pos[v[i]] = i;	// 映射对应的下标father[i] = i;	// 对应下标 根节点初始化}for(int i = 1;i <= n;++i){// 如果对应的元素存在的话,我们将其元素的下标与当前的下标进行操作合并对应的集合if(pos[b - v[i]]) Union(i,pos[b - v[i]]);	// 另一元素存在 集合 b 那么我们合并对应下标 else Union(A,i);	//如果不符合那么合并另一个集合if(pos[a - v[i]]) Union(i,pos[a - v[i]]);	// 另一元素存在 集合 a 那么我们合并对应下标 else Union(B,i);	//如果不符合那么合并另一个集合}A = Finds(A),B = Finds(B);	// 根据对应的 结合 根节点元素查找;if(A == B) cout << "NO" << endl;	// 如果最终集合 A 和 集合 B 的根节点也给合并了,说明无解 NOelse{cout << "YES" << endl;for(int i = 1;i <= n;++i){
// 			cout << bool(Finds(i) == B) << ' ';		// 这样输出是错误的,有可能这里没考虑一个情况,就是 A == B 的时候,也有可能返回值的原因if(Finds(i) == A) cout << "0 ";else cout << "1 ";}cout << endl;}
}signed main()
{IOS;int ___t = 1;while(___t--) solve();	return 0;
}

最后提交:

http://www.yayakq.cn/news/899991/

相关文章:

  • 品牌网站建设哪里有广州营销型网站建设培训
  • 免费电子商务网站建设wordpress tag无法找到该页
  • 北斗手表官方网站求职seo推荐
  • 毕设网站开发需要做什么百度一下你就知道手机版官网
  • phpcms 网站访问统计宁波超值关键词优化
  • 孟津网站开发做网站 给源代码
  • 营销案例网站wordpress性能好差
  • 算命公司网站建设制作开发方案在线支付网站制作
  • 个人主页自助建站中国建设网上银行个人登录
  • 做直播网站软件做美食类网站分析
  • 滨州网站建设腾度免费网站流量
  • 网站建设中upl连接网站运营怎样做
  • 新网站外链怎么做免费制作app平台
  • 北京市保障性住房建设投资中心网站电脑网页游戏推荐
  • 聚美优品的pc网站建设西安房产信息网
  • 绿色食品网站建设论文重庆网站建设哪家公司哪家好
  • 网站建设及运营 经营范围十大社区团购平台排名
  • 制作团体网站上海做网站需要多少钱
  • 仿牌网站优化网上商城网站设计
  • 巴中市建设局新网站ui设计怎么收费
  • 网站建设中销售人员会问客户的问题郑州有免费建网站的公司吗
  • 介绍网站开发的意义怎么获取免费的wordpress
  • 农业企业网站建设流程微信公众号开发者中心
  • 郓城做网站哪家好品牌策划案模板
  • 济宁北湖旅游度假区建设局网站四川公共资源交易中心
  • 如何获取网站根目录试列出网站开发建设的步骤
  • 灌阳县建设局门户网站wordPress紧凑主题
  • 网页建站建设教程轻量应用服务器wordpress
  • 魔方 网站建设 有限公司贵大网站建设多少钱
  • 做电影网站用什么主机好中国建设银行网站股份结构变化