poj 1830 開關問題

来源:http://www.cnblogs.com/hxer/archive/2016/02/03/5180411.html
-Advertisement-
Play Games

開關問題 題意:給n(0 < n < 29)開關的初始和最終狀態(01表示),以及開關之間的關聯關係(關聯關係是單向的輸入a b表示a->b),問有幾種方式得到最終的狀態。否則輸出字元字面值。 1.與poj 1222的區別:關聯為單向,需要預處理出每個開關對自己的關聯(開始在輸入關聯關係中處理自身的


開關問題

題意:給n(0 < n < 29)開關的初始和最終狀態(01表示),以及開關之間的關聯關係(關聯關係是單向的輸入a b表示a->b),問有幾種方式得到最終的狀態。否則輸出字元字面值。

1.與poj 1222的區別:關聯為單向,需要預處理出每個開關對自己的關聯(開始在輸入關聯關係中處理自身的關聯,WA了兩發),操作的矩陣(變換的矩陣)為初始狀態XOR最終狀態;

2.處理完之後判斷繫數全為0的最終結果a[k][var]是否為0來判斷是否無解。同時如有n個自由變元,由於每個變元只有兩種狀態,所以只有2^n個方案。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<map>
#include<queue>
#include<vector>
#include<cmath>
#include<stdlib.h>
#include<time.h>
using namespace std;
#define rep0(i,l,r) for(int i = (l);i < (r);i++)
#define rep1(i,l,r) for(int i = (l);i <= (r);i++)
#define rep_0(i,r,l) for(int i = (r);i > (l);i--)
#define rep_1(i,r,l) for(int i = (r);i >= (l);i--)
#define MS0(a) memset(a,0,sizeof(a))
#define MS1(a) memset(a,-1,sizeof(a))
int a[35][35];
int equ,var;
int x[35];
void debug()
{
    int i,j;
    rep0(i,0,equ){
        rep1(j,0,var)
            cout<<a[i][j]<<" ";
        cout<<endl;
    }
}
int Guass()
{
    int i,j,k,free_var = 0,row,col;
    for(row = 0,col = 0;row < equ && col < var;row++,col++){
        int mx = row;
        rep0(j,row+1,equ)
            if(abs(a[j][col]) > abs(a[mx][col]))  mx = j;
        if(a[mx][col] == 0){
            row--;  // 行不變;
            free_var++;
            continue;
        }
        if(mx != row)
            rep1(k,col,var)
                swap(a[row][k],a[mx][k]);
        rep0(j,row+1,equ){
            if(a[j][col]){    //第j盞燈也會對第i盞燈產生影響
                rep1(k,col,var)
                    a[j][k] ^= a[row][k];
            }
        }
    }
    //debug();
    for(;row < equ;row++)if(a[row][var] != 0) return -1;    //無解;
    if(free_var != 0) return free_var;
    rep_1(i,var-1,0){   //求解的變數的個數,並不是方程的個數;
        x[i] = a[i][var];
        rep0(j,i+1,equ)
            x[i] ^= (a[i][j] && x[j]);  //第j個燈會影響到第i盞燈,同時第j盞燈也會亮。
    }
    return 0;
}
void init()
{
    int i,j,k,n;
    MS0(a);MS0(x);
    scanf("%d",&n);
    equ = var = n;
    int x,l,r;
    rep0(i,0,n) scanf("%d",&a[i][n]);
    rep0(i,0,n) scanf("%d",&x),a[i][n] ^= x;
    rep0(i,0,n) a[i][i] = 1;    //沒有關聯要格外賦值;
    while(scanf("%d %d",&l,&r) == 2 && l+r){
        a[r-1][l-1] = 1;
    }
}
int main()
{
    int T,kase = 1,i;
    cin>>T;
    while(T--){
        init();
        int ret = Guass();
        if(ret == -1) puts("Oh,it's impossible~!!");
        else printf("%d\n",1<<ret);
    }
    return 0;
}
View Code

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Boss說,我們買了個權威證書,不如做全站式的https吧,讓用戶打開主頁就能看到受信任的綠標。於是我們就開始了填坑之旅。 【只上主域好不好?】 不好。。。console會報出一大堆warning因為圖片域沒有https~瀏覽器證書符號也不是綠色的~ 【在哪裡解密SSL?】 大網站都是架構複雜的啦~
  • 一、前言 本篇文章需要讀者有一點 Node.js 基礎的瞭解,並且已經安裝了 Node.js (node、npm),但並不需要有 Nokit 的知識,本文將簡單介紹 Nokitjs 的安裝使用,並編寫一個最簡單的 "Hello Word" 。 文中示例是在 Mac OSX 上完成的,整個步驟和 Li
  • 註意:本篇博客,主要參考自《深入理解Java虛擬機(第二版)》 1、對象在記憶體中存儲的佈局分為三塊 對象頭 存儲對象自身的運行時數據:Mark Word(在32bit和64bit虛擬機上長度分別為32bit和64bit),包含如下信息: 對象hashCode 對象GC分代年齡 鎖狀態標誌(輕量級鎖、
  • 如果給定一個list或tuple,我們可以通過for迴圈來遍歷這個list或tuple,這種遍歷我們稱為迭代(Iteration)。 在Python中,迭代是通過for ... in來完成的。 for key in d: print(key) 因為dict的存儲不是按照list的方式順序排列,所以,...
  • 以一元多項式加法運算為例: A,B可用線性鏈表可以表示為: “和多項式”鏈表如下(圖中的長方框表示已經被釋放的結點): #include <stdio.h> #include <stdlib.h> typedef struct Polyn{ int data; int index; struct P
  • Day14 集合框架01 體系概述02 共性方法03 迭代器04 List集合共性方法05 ListIterator06 List集合具體對象特點07 Vector中的枚舉 01 體系概述 集合類為什麼出現集合類?面向對象語言對事物的體現都是以對象的形式,所以為了方便對多個對象的操作,就需要對對象進
  • 註意:本篇博客,主要參考自以下三本書 《分散式Java應用:基礎與實踐》 《深入理解Java虛擬機(第二版)》 《突破程式員基本功的16課》 說明:關於JVM記憶體結構,查看《第一章 JVM記憶體結構》,下麵所講的JVM記憶體分配主要是指在Hotspot JVM下新建對象在堆記憶體中分配的情況。 1、創建一
  • 上代碼 $arr = array( 'a'=> 'a11', 'b'=> 'b22', 'c'=> 'c33', ); foreach ($arr as $k=>&$v){ // Do somethind } foreach ($arr as $k=>$v){ var_dump($v); } 這樣的
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...