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

适合学生做网页练习的网站培训机构管理系统哪个好

适合学生做网页练习的网站,培训机构管理系统哪个好,dedecms旅游网站模板,网站优化的前景【题目链接】 洛谷 P1955 [NOI2015] 程序自动分析 【题目考点】 1. 并查集 2. 离散化 【解题思路】 多组数据问题,对于每组数据,有多个 x i x j x_ix_j xi​xj​或 x i ≠ x j x_i \neq x_j xi​xj​的约束条件。 所有相等的变量构成一个集合&…

【题目链接】

洛谷 P1955 [NOI2015] 程序自动分析

【题目考点】

1. 并查集
2. 离散化

【解题思路】

多组数据问题,对于每组数据,有多个 x i = x j x_i=x_j xi=xj x i ≠ x j x_i \neq x_j xi=xj的约束条件。

所有相等的变量构成一个集合,不相等的变量在不同的集合。可以使用并查集表示集合。
该题的变量编号 i i i j j j最大可达到 1 0 9 10^9 109,无法直接作为并查集fa数组的下标,所以需要先对所有输入的 i i i j j j进行离散化。由于每组数据输入的约束条件的数量 n ≤ 1 0 5 n\le 10^5 n105,每一个约束条件最多新增两个变量编号。因此在对变量编号进行离散化后,最多存在 2 ∗ 1 0 5 2*10^5 2105个元素,离散化后的数值的范围为 1 ∼ 2 ∗ 1 0 5 1\sim 2*10^5 12105,可以作为fa数组的下标。

  • 先遍历所有约束。对于 x i = x j x_i = x_j xi=xj,那么可以认为 x i x_i xi x j x_j xj同属于一个集合,将 x i x_i xi x j x_j xj所在的集合合并。
  • 再次遍历所有约束,对于 x i ≠ x j x_i \neq x_j xi=xj,而且 x i x_i xi x j x_j xj已属于同一集合,那么该问题中的约束条件无法都被满足,输出NO。

当看完所有约束后,如果没有输出NO,则以上约束条件可以同时满足,输出YES。

【题解代码】

#include<bits/stdc++.h>
using namespace std;
#define N 100005
struct Node
{int i, j, e;
};
vector<Node> op;
vector<int> t;
int fa[2*N];//不同的变量编号最多有2N个,因此并查集fa数组长度设为2N 
void init()
{for(int i = 1; i < 2*N; ++i)fa[i] = i;
}
int find(int x)
{return x == fa[x] ? x : fa[x] = find(fa[x]);
}
void merge(int x, int y)
{fa[find(x)] = find(y);
}
void discretization()
{sort(t.begin(), t.end());t.erase(unique(t.begin(), t.end()), t.end());for(Node &p : op){p.i = upper_bound(t.begin(), t.end(), p.i)-t.begin();//离散化后,变量编号范围为1~2*10^5 p.j = upper_bound(t.begin(), t.end(), p.j)-t.begin();}
}
bool isMatch()//是否可以满足给定的所有约束 
{for(Node p : op) if(p.e == 0 && find(p.i) == find(p.j))return false;return true;
}
int main()
{int tn, n, i, j, e;cin >> tn;while(tn--){op.clear();t.clear();init();cin >> n;for(int k = 1; k <= n; ++k){cin >> i >> j >> e;op.push_back(Node{i, j, e});t.push_back(i);t.push_back(j);}discretization();for(Node p : op) if(p.e == 1)//如果是xi=xj merge(p.i, p.j);cout << (isMatch() ? "YES" : "NO") << '\n';}return 0;
}
http://www.dtcms.com/wzjs/31319.html

相关文章:

  • 凤岗网站建设网站域名查询ip地址
  • 网站页面改版降权首页百度
  • 徐州网站建设培训班长沙seo步骤
  • 域名注册了 如何做网站百度怎么精准搜关键词
  • 什么网站可以免费做视频的软件下载北京网站优化服务商
  • 用PYTHON3 做网站百度竞价品牌广告
  • 山东企业网站备案网络营销专业代码
  • 网站服务内容怎么写域名网
  • 中山网站建设与设计提高工作效率的措施
  • 通州免费网站建设军事新闻 今日关注
  • 甘肃兰州旅游攻略seo实战技巧100例
  • 网站建设与维护的软件互联网宣传方式有哪些
  • 淅川微网站建设百度热门搜索排行榜
  • 购物网站备案费用什么是关键词广告
  • 网站建设销售实训报告南宁seo规则
  • 青海省建设厅职业注册官方网站广东企业网站seo报价
  • 织梦网站防止注入网络培训seo
  • 自己做网站 有名6推广方案怎么做
  • 域名解析到网站安徽seo
  • 国外优秀网站设计欣赏长春seo排名收费
  • 安阳市网站建设的公司今日nba比赛直播
  • 网站解除域名绑定网站整合营销推广
  • 常州营销网站建设最新热点新闻事件素材
  • 全球速卖通站长工具之家seo查询
  • 域名网站有哪些山东自助seo建站
  • 台州做网站比较好的有哪些百度推广的步骤
  • 电子兼职网站建设东莞企业网站推广
  • 室内装修设计图片阳山网站seo
  • 安徽省建设厅证书查询官方网站长沙网络推广平台
  • 全国房地产网站排名优化工具下载