POJ-1830
| Time Limit: 1000MS | Memory Limit: 30000K | |
| Total Submissions: 6294 | Accepted: 2393 | 
Description
Input
每组测试数据的格式如下:
第一行 一个数N(0 < N < 29)
第二行 N个0或者1的数,表示开始时N个开关状态。
第三行 N个0或者1的数,表示操作结束后N个开关的状态。
接下来 每行两个数I J,表示如果操作第 I 个开关,第J个开关的状态也会变化。每组数据以 0 0 结束。
Output
Sample Input
2
3
0 0 0
1 1 1
1 2
1 3
2 1
2 3
3 1
3 2
0 0
3
0 0 0
1 0 1
1 2
2 1
0 0
Sample Output
4
Oh,it's impossible~!!
Hint
第一组数据的说明: 
一共以下四种方法:
操作开关1
操作开关2
操作开关3
操作开关1、2、3 (不记顺序)
/**
题意:给一些开关,开某一个开关之后有的开关也会变化
做法:高斯消元 线性代数
**/
#include <iostream>
#include <string.h>
#include <stdio.h>
#include <algorithm>
#include <cmath>
#define maxn 50
using namespace std;
int mmap[maxn][maxn];
int start[maxn];
int eed[maxn];
int guess(int equ,int val)
{
int k=,col = ;
int max_r = ;
for(k=; k<equ&&col<val; k++,col++)
{
max_r = k;
for(int i=k+; i<equ; i++)
{
if(abs(mmap[i][col]) > abs(mmap[max_r][col]))
{
max_r = i;
}
}
if(max_r != k)
{
for(int i=k; i<val+; i++)
{
swap(mmap[k][i],mmap[max_r][i]);
}
}
if(mmap[k][col] == )
{
k--;
continue;
}
for(int i=k+; i<equ; i++)
{
if(mmap[i][col] != )
{
for(int j=col; j<val+; j++)
{
mmap[i][j] ^= mmap[k][j];
}
}
}
}
///上三角
for(int i=k; i<equ; i++)
{
if(mmap[i][col]!=) return -;
}
return val-k;
}
int main()
{
//#ifndef ONLINE_JUDGE
// freopen("in.txt","r",stdin);
//#endif // ONLINE_JUDGE
int T;
scanf("%d",&T);
while(T--)
{
int n;
scanf("%d",&n);
memset(start,,sizeof(start));
memset(eed,,sizeof(eed));
for(int i=; i<n; i++)
{
scanf("%d",&start[i]);
}
for(int i=; i<n; i++)
{
scanf("%d",&eed[i]);
}
int u,v;
memset(mmap,,sizeof(mmap));
while(scanf("%d %d",&u,&v))
{
if(u == && v == ) break;
u--;
v--;
mmap[v][u] = ;
}
for(int i=; i<n; i++)
{
mmap[i][i] = ;
}
for(int i=; i<n; i++)
{
mmap[i][n] = start[i]^eed[i];
}
int res = guess(n,n);
if(res == -) printf("Oh,it's impossible~!!\n");
else printf("%d\n",<<res);
}
return ;
}
POJ-1830的更多相关文章
- 【POJ 1830】 开关问题 (高斯消元)
		开关问题 Description 有N个相同的开关,每个开关都与某些开关有着联系,每当你打开或者关闭某个开关的时候,其他的与此开关相关联的开关也会相应地发生变化,即这些相联系的开关的状态如果原来为 ... 
- POJ 1830 开关问题(高斯消元)题解
		思路:乍一看好像和线性代数没什么关系.我们用一个数组B表示第i个位置的灯变了没有,然后假设我用u[i] = 1表示动开关i,mp[i][j] = 1表示动了i之后j也会跟着动,那么第i个开关的最终状态 ... 
- POJ 1222      POJ 1830      POJ  1681   POJ 1753     POJ 3185   高斯消元求解一类开关问题
		http://poj.org/problem?id=1222 http://poj.org/problem?id=1830 http://poj.org/problem?id=1681 http:// ... 
- POJ 1830 开关问题(高斯消元求解的情况)
		开关问题 Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 8714 Accepted: 3424 Description ... 
- 数学 --- 高斯消元 POJ 1830
		开关问题 Problem's Link: http://poj.org/problem?id=1830 Mean: 略 analyse: 增广矩阵:con[i][j]:若操作j,i的状态改变则con[ ... 
- POJ 1830 开关问题 【01矩阵 高斯消元】
		任意门:http://poj.org/problem?id=1830 开关问题 Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 1 ... 
- POJ 1830 开关问题  高斯消元,自由变量个数
		http://poj.org/problem?id=1830 如果开关s1操作一次,则会有s1(记住自己也会变).和s1连接的开关都会做一次操作. 那么设矩阵a[i][j]表示按下了开关j,开关i会被 ... 
- 【POJ 1830】 开关问题
		[题目链接] http://poj.org/problem?id=1830 [算法] 列出异或方程组,用高斯消元求解 [代码] #include <algorithm> #include ... 
- POJ 1830 开关问题 (高斯消元)
		题目链接 题意:中文题,和上篇博客POJ 1222是一类题. 题解:如果有解,解的个数便是2^(自由变元个数),因为每个变元都有两种选择. 代码: #include <iostream> ... 
- poj 1830 开关问题
		开关问题 题意:给n(0 < n < 29)开关的初始和最终状态(01表示),以及开关之间的关联关系(关联关系是单向的输入a b表示a->b),问有几种方式得到最终的状态.否则输出字 ... 
随机推荐
- mysql前缀索引优化示例
			现有一数据表,数据量79W, 微信openid字段为定长28位char型,目前是做的全字段索引,需要做一下索引优化,. 我们先来看下选择性, 全字段索引的: SELECT COUNT(DISTINCT ... 
- 《Java程序设计》第六周学习总结 20165218 2017-2018-1
			20165218 2017-2018-1 <Java程序设计>第六周学习总结 教材学习内容总结 第8章 常用实用类 String类 不可以有子类 在java.lang 包中,被默认引入 S ... 
- URAL.1033 Labyrinth (DFS)
			URAL.1033 Labyrinth (DFS) 题意分析 WA了好几发,其实是个简单地DFS.意外发现这个俄国OJ,然后发现ACRUSH把这个OJ刷穿了. 代码总览 #include <io ... 
- purfer序列题表
			purfer序列是对于带编号(互不相同)的无根树进行编码得到的,对于同样的n个顶点,其有n-2项,有n^(n-2)种,而且每种都合法(如果只要求他是一棵树的话)(可以通过证明翻译过程维持了各部分的树的 ... 
- android getpost代码
			GetPostUtil public class GetPostUtil { /** * 向指定URL发送GET方法的请求 * * @param url * 发送请求的URL * @param par ... 
- swift的UIlabel
			let label = UILabel(frame:CGRect(x:,y:,width:,height:)); label.text="i am a am a label am a lab ... 
- c++11新特性之future
			std::future可以从异步任务中获取结果,一般与std::async配合使用,std::async用于创建异步任务,实际上就是创建一个线程执行相应任务. 先看段代码: #include < ... 
- ARM指令集、Thumb指令集、Thumb-2指令集
			MCU使用什么指令集主要由内核决定的,比如Cortex-M3使用的是Thumb-2指令集 ARM指令集: 编代码全部是 32bits 的,每条指令能承载更多的信息,因此使用最少的指令完成功能, 所以在 ... 
- UVALive-4670 Dominating Patterns  / 洛谷 3796 【模板】AC自动机
			https://vjudge.net/problem/UVALive-4670 中文题面:https://www.luogu.org/problem/show?pid=3796 AC自动机模板 注意如 ... 
- Quick-Cocos2dx-Community_3.6.3_Release 中 tolua++ 使用方法
			参考文章1 http://www.aichengxu.com/view/45851 参考文章2 http://blog.csdn.net/pawleft/article/details/5212744 ... 
