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

营销型网站建设广州美国婚恋网站排名

营销型网站建设广州,美国婚恋网站排名,如何做公司的网站,网站做轮播图的意义活动 - AcWing 给定 n 个还未赋值的布尔变量 x1∼xn。 现在有 m 个条件,每个条件的形式为 “xi 为 0/1 或 xj 为 0/1 至少有一项成立”,例如 “x1 为 1 或 x3 为 0”、“x8 为 0 或 x4 为 0” 等。 现在,请你对这 n 个布尔变量进行赋值&am…

活动 - AcWing

给定 n 个还未赋值的布尔变量 x1∼xn。

现在有 m 个条件,每个条件的形式为 “xi 为 0/1  xj 为 0/1 至少有一项成立”,例如 “x1 为 1 或 x3 为 0”、“x8 为 0 或 x4 为 0” 等。

现在,请你对这 n 个布尔变量进行赋值(0 或 1),使得所有 m 个条件能够成立。

输入格式

第一行包含两个整数 n,m。

接下来 m 行,每行包含四个整数 i,a,j,b,用来描述一个条件,表示 “xi 为 a 或 xj 为 b”。

输出格式

如果问题有解,则第一行输出 POSSIBLE,第二行输出 n 个整数表示赋值后的 n 个变量 x1∼xn 的值(0 或 1),整数之间用单个空格隔开。

如果问题无解,则输出一行 IMPOSSIBLE 即可。

如果答案不唯一,则输出任意一种正确答案即可。

数据范围

1≤n,m≤106,
1≤i,j≤n,
0≤a,b≤1

输入样例:
3 2
1 1 3 1
2 0 3 0
输出样例:
POSSIBLE
1 1 0

解析: 

该文件无法打开 - AcWing

 本题是 2-SAT 问题的模板题,对于每个条件 a∧b,得出推导公式 −a→b 和 −b→a,按照推导公式建图,然后求强连通分量并进行缩点,如果任意一个变量的两种取值在同一个强连通分量中,说明无解。否则枚举每个变量,选取所在强连通分量拓扑序靠后的取值。

#include<iostream>
#include<string>
#include<cstring>
#include<cmath>
#include<ctime>
#include<algorithm>
#include<utility>
#include<stack>
#include<queue>
#include<vector>
#include<set>
#include<math.h>
#include<map>
#include<sstream>
#include<deque>
#include<unordered_map>
#include<unordered_set>
#include<bitset>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
const int N = 2e6+10, M = 2e6+ 10, INF = 0x3f3f3f3f;
int n, m;
int h[N], e[M], ne[M], idx;
int dfn[N], low[N], ts;
int stk[N], top;
bool in_stk[N];
int id[N],cnt;void add(int a, int b) {e[idx] = b, ne[idx] = h[a], h[a] = idx++;
}int tarjan(int u) {dfn[u] = low[u] = ++ts;stk[++top] = u, in_stk[u] = 1;for (int i = h[u]; i != -1; i = ne[i]) {int j = e[i];if (!dfn[j]) {tarjan(j);low[u] = min(low[u], low[j]);}else if (in_stk[j]) {low[u] = min(low[u], dfn[j]);}}if (dfn[u] == low[u]) {int y;cnt++;do {y = stk[top--];in_stk[y] = 0;id[y] = cnt;} while (y != u);}
}int main() {cin >> n >> m;memset(h, -1, sizeof h);for (int i = 1,x,a,y,b; i <= m; i++) {scanf("%d%d%d%d", &x, &a, &y, &b);x--, y -- ;add(2 * x + !a, 2 * y + b);add(2 * y + !b, 2 * x + a);}for (int i = 0; i < 2 * n; i++) {if (!dfn[i])tarjan(i);}for (int i = 0; i < n; i++) {if (id[i * 2] == id[2 * i + 1]) {cout << "IMPOSSIBLE" << endl;return 0;}}cout << "POSSIBLE" << endl;for (int i = 0; i < n; i++) {if (id[i * 2] < id[i * 2 + 1])printf("0 ");else printf("1 ");}return 0;
}

http://www.fp688.cn/news/142699.html

相关文章:

  • 一个可以看qq空间的网站网站检测
  • 怎么做公众号网站吗免费网络推广100种方法
  • 个人网站备案做淘宝客百度关键词排名价格
  • 成都网站建设公司百度权重划分等级
  • 光明随心订网站怎么做谷歌google中文登录入口
  • 做网站用的语言新手小白怎么做跨境电商
  • 国外有没有做物理小实验的网站网络营销广告
  • 新疆交通投资集团有限责任公司官网建设企业网站seo平台
  • 成立公司一年需要多少费用网站优化公司开始上班了
  • 做网站都需要了解什么厦门百度seo公司
  • 做游戏网站在哪里找百度客服中心
  • 新疆生产建设兵团 经信委网站优化大师的功能有哪些
  • 手机网站建设的整体流程图中国站长网入口
  • 网站帮企业做推广价格怎么算推广放单平台
  • 全国公安机关网站备案线上购买链接
  • 网站营销公司微信平台推广方法
  • php做简单网站教程seo推广排名平台有哪些
  • 1920的做网站做多大网络公司seo教程
  • 做门窗网站怎么做站长工具查询域名信息
  • 上海网站建设永灿14年品牌广告网络营销
  • 山东高端网站建设方案怎么申请一个网站
  • 做网站推广的公司广告平台网
  • 那些网站可以做条形码企点客服
  • 广州站到广州南站地铁要多久公司产品推广方案
  • a站为什么会凉品牌策略有哪些
  • 一个完整网站开发需要什么技术关键词排名 收录 查询
  • 创业平台网站新闻软文自助发布平台
  • 东莞seo整站优化火速有什么好的网站吗
  • 动图从哪个网站做怎么做业务推广技巧
  • 涿州网站建设国外免费舆情网站有哪些软件