[luoguP2962] [USACO09NOV]灯Lights(高斯消元 + dfs)
先进行高斯消元
因为要求最少的开关次数,那么:
对于关键元,我们可以通过带入消元求出,
对于自由元,我们暴力枚举,进行dfs,因为只有开关两种状态,0或1
#include <cmath>
#include <cstdio>
#include <iostream>
#define N 40 using namespace std; int n, m, sum, mn = ~(1 << 31);
int a[N][N], ans[N]; inline void Guass()
{
int i, j, k;
for(j = 1; j <= n; j++)
{
k = j;
for(i = j; i <= n; i++)
if(a[i][j] > a[k][j])
k = i;
if(k != j) swap(a[k], a[j]);
for(i = j + 1; i <= n; i++)
if(a[i][j])
for(k = j; k <= n + 1; k++)
a[i][k] ^= a[j][k];
}
} inline void dfs(int now, int sum)
{
if(sum >= mn) return;
if(!now)
{
mn = min(mn, sum);
return;
}
int i;
if(a[now][now])
{
ans[now] = a[now][n + 1];
for(i = now + 1; i <= n; i++)
ans[now] ^= (ans[i] * a[now][i]);
dfs(now - 1, sum + bool(ans[now]));
}
else
{
ans[now] = 0;
dfs(now - 1, sum);
ans[now] = 1;
dfs(now - 1, sum + 1);
}
} int main()
{
int i, x, y;
scanf("%d %d", &n, &m);
for(i = 1; i <= n; i++) a[i][i] = 1, a[i][n + 1] = 1;
for(i = 1; i <= m; i++)
{
scanf("%d %d", &x, &y);
a[x][y] = 1;
a[y][x] = 1;
}
Guass();
dfs(n, 0);
printf("%d\n", mn);
return 0;
}
[luoguP2962] [USACO09NOV]灯Lights(高斯消元 + dfs)的更多相关文章
- luogu P2962 [USACO09NOV]灯Lights 高斯消元
		
目录 题目链接 题解 题目链接 luogu P2962 [USACO09NOV]灯Lights 题解 可以折半搜索 map合并 复杂度 2^(n / 2)*logn 高斯消元后得到每个点的翻转状态 爆 ...
 - BZOJ1770:[USACO]lights 燈(高斯消元,DFS)
		
Description 貝希和她的閨密們在她們的牛棚中玩遊戲.但是天不從人願,突然,牛棚的電源跳閘了,所有的燈都被關閉了.貝希是一個很膽小的女生,在伸手不見拇指的無盡的黑暗中,她感到驚恐,痛苦與絕望. ...
 - bzoj 1770: [Usaco2009 Nov]lights 燈【高斯消元+dfs】
		
参考:https://blog.csdn.net/qq_34564984/article/details/53843777 可能背了假的板子-- 对于每个灯建立方程:与它相邻的灯的开关次数的异或和为1 ...
 - Flip Game (高斯消元 || dfs)
		
Flip game is played on a rectangular 4x4 field with two-sided pieces placed on each of its 16 square ...
 - [Usaco2009 Nov]lights(高斯消元)
		
luogu 点灯游戏应该很多人都在小时候頽过吧 反正我直到现在也不会 很明显一个灯最多只需要点一次 然后高斯消元 解完肯定剩自由元(就是那些全是0的行) 然后这些都爆搜 由于剩下的自由元不会太多 所以 ...
 - Codeforces 1163E 高斯消元 + dfs
		
题意:给你一个集合,让你构造一个长度尽量长的排列,使得排列中任意相邻两个位置的数XOR后是集合中的数. 思路:我们考虑枚举i, 然后判断集合中所有小于1 << i的数是否可以构成一组异或空 ...
 - POJ1288 Sly Number(高斯消元 dfs枚举)
		
由于解集只为{0, 1, 2}故消元后需dfs枚举求解 #include<cstdio> #include<iostream> #include<cstdlib> ...
 - BZOJ 2466 中山市选2009 树 高斯消元+暴力
		
题目大意:树上拉灯游戏 高斯消元解异或方程组,对于全部的自由元暴力2^n枚举状态,代入计算 这做法真是一点也不优雅... #include <cstdio> #include <cs ...
 - 【dfs】【高斯消元】【异或方程组】bzoj1770 [Usaco2009 Nov]lights 燈 / bzoj2466 [中山市选2009]树
		
经典的开关灯问题. 高斯消元后矩阵对角线B[i][i]若是0,则第i个未知数是自由元(S个),它们可以任意取值,而让非自由元顺应它们,得到2S组解. 枚举自由元取0/1,最终得到最优解. 不知为何正着 ...
 
随机推荐
- Python打开目录下所有文件
			
用Python打开指定目录下所有文件,统计文件里特定的字段信息. 这里是先进入2017-02-25到2017-03-03目录,然后进入特定IP段目录下,最后打开文件进行统计 import os, gl ...
 - 使用原生javascript实现jquery的$(function(){ })
			
在使用jquery的时候,经常用到$(function(){})方法或者是$(document).read(function(){})来作为页面dom节点加载完成之后javascript的执行入口,现 ...
 - Spring-bean(零)
			
内容提要:红为1,黄2,绿3 -----配置形式:基于xml文件的方式:基于注解的方式 -----Bean的配置方式:通过全类名(反射),通过工厂方法(静态工厂方法&实例工厂方法),Facto ...
 - JS内置对象练习(慕课网题目)
			
效果图: XXXX年XX月X日 星期X--班级总分为:81 格式要求: 1.显示打印的日期. 格式为类似“XXXX年XX月XX日 星期X” 的当前的时间. 2.计算出该班级的平均分(保留整数). 同学 ...
 - SQL中的SELECT_简单查询语句总结
			
--以scott用户下的dept和emp表为例 --注意:如果scott用户不能使用,请使用system用户登录--解锁scott用户ALTER USER SCOTT ACCOUNT UNLOCK;- ...
 - SQL Server 查询锁表和接锁表
			
SQL Server 查询锁表 select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) as tableNa ...
 - pspad的一个怪现象:在一些空行的位置出现个别不该出现的字符
			
在用pspad编辑一个外来文件时,发现有许多空行的结尾会出现一些单个字符,字符内容与翻页前那一页相应位置的字符相同. 好奇怪.上网找不到原因.pspad太好用了,不想因此放弃. 仔细观察,这些空行往往 ...
 - 11G GI启动顺序
			
--11gR2 Clusterware and Grid Home - What You Need to Know (文档 ID 1053147.1) 上图来自<Oracle C ...
 - (转)Spring管理的Bean的生命周期
			
http://blog.csdn.net/yerenyuan_pku/article/details/52834011 bean的初始化时机 前面讲解了Spring容器管理的bean的作用域.接着我们 ...
 - Keil Debug (printf) Viewer
			
Debug (printf) Viewer Home » µVision Windows » Debug (printf) Viewer The Debug (printf) Viewer windo ...