Description

根据宪法,Byteland民主共和国的公众和平委员会应该在国会中通过立法程序来创立。 不幸的是,由于某些党派代表之间的不和睦而使得这件事存在障碍。 此委员会必须满足下列条件:

  • 每个党派都在委员会中恰有1个代表,
  • 如果2个代表彼此厌恶,则他们不能都属于委员会。

每个党在议会中有2个代表。代表从1编号到2n。 编号为2i-1和2i的代表属于第I个党派。 
任务 写一程序:

  • 从文本文件读入党派的数量和关系不友好的代表对,
  • 计算决定建立和平委员会是否可能,若行,则列出委员会的成员表, 结果写入文本文件。

Input(多组输入)

在文本文件的第一个行有2非负整数n和m。 他们各自表示:党派的数量n,1 <=n<=8000和不友好的代表对m,0 <=m <=20000。 在下面m行的每行为一对整数a,b,1<=a

Output

如果委员会不能创立,文本文件中应该包括单词NIE。若能够成立,文本文件SPO.OUT中应该包括n个从区间1到2n选出的整数,按升序写出,每行一个,这些数字为委员会中代表的编号。如果委员会能以多种方法形成,请输出字典序最小的一个(上一个人并没有看到这一句 your program may write mininum number sequence.)

Sample Input

3 2
1 3
2 4

Sample Output

1
4
5
解析:
  就是蓝书上的模板。。记得在输入的时候--,因为。。i^1 如果i是1 那么i^1就是0了。。
  注意输出就好了 还有注意i和~i分别代表什么 在这个题中 i代表i去 ~i代表i^1去
#include <iostream>
#include <cstdio>
#include <sstream>
#include <cstring>
#include <map>
#include <cctype>
#include <set>
#include <vector>
#include <stack>
#include <queue>
#include <algorithm>
#include <cmath>
#include <bitset>
#define rap(i, a, n) for(int i=a; i<=n; i++)
#define rep(i, a, n) for(int i=a; i<n; i++)
#define lap(i, a, n) for(int i=n; i>=a; i--)
#define lep(i, a, n) for(int i=n; i>a; i--)
#define rd(a) scanf("%d", &a)
#define rlld(a) scanf("%lld", &a)
#define rc(a) scanf("%c", &a)
#define rs(a) scanf("%s", a)
#define pd(a) printf("%d\n", a);
#define plld(a) printf("%lld\n", a);
#define pc(a) printf("%c\n", a);
#define ps(a) printf("%s\n", a);
#define MOD 2018
#define LL long long
#define ULL unsigned long long
#define Pair pair<int, int>
#define mem(a, b) memset(a, b, sizeof(a))
#define _ ios_base::sync_with_stdio(0),cin.tie(0)
//freopen("1.txt", "r", stdin);
using namespace std;
const int maxn = 1e5 + , INF = 0x7fffffff, LL_INF = 0x7fffffffffffffff;
int n, m;
vector<int> G[maxn * ];
bool mark[maxn * ];
int S[maxn * ], c; bool dfs(int x)
{
if(mark[x ^ ]) return false;
if(mark[x]) return true;
mark[x] = true;
S[c++] = x;
for(int i = ; i < G[x].size(); i++)
{
if(!dfs(G[x][i])) return false;
}
return true;
} void init()
{
for(int i = ; i < maxn; i++) G[i].clear();
mem(mark, );
} bool solve()
{
for(int i = ; i < n * ; i += )
{
if(!mark[i] && !mark[i + ])
{
c = ;
if(!dfs(i))
{
while(c > ) mark[S[--c]] = false;
if(!dfs(i + )) return false;
}
}
}
return true;
}
int main()
{ int u, v;
while(cin >> n >> m)
{
init();
for(int i = ; i < m; i++)
{
rd(u), rd(v);
u--, v--;
G[u].push_back(v^);
G[v].push_back(u^);
}
if(!solve())
{
puts("NIE");
continue;
}
for(int i = ; i < n * ; i += )
{
if(mark[i])
{
cout << i + << endl;
}
else
cout << i + << endl;
}
} return ;
}
04-29 00:19