2594 解藥還是毒藥

来源:http://www.cnblogs.com/zwfymqz/archive/2017/07/10/7146974.html
-Advertisement-
Play Games

時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 題解 查看運行結果 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 時間限制: 1 ...


時間限制: 1 s  空間限制: 128000 KB  題目等級 : 鑽石 Diamond     題目描述 Description

Smart研製出對付各種癥狀的解藥,可是他一個不小心,每種藥都小小地配錯了一點原料,所以這些藥都有可能在治愈某些病癥的同時又使人患上某些別的病癥(你可能會問那…那是解藥還是毒藥啊?)……,經過Smart的努力,終於弄清了每種藥的具體性能,他會把每種藥能治愈的病癥和能使人患上的病癥列一張清單給你,然後你要根據這張清單找出能治愈所有病癥的最少藥劑組合……順便說一聲,病癥的數目不超過10種,而且他的藥是用不完的,就是說每種藥劑都可以被重覆使用。

輸入描述 Input Description

給你們的單子里第一行是病癥的總數n(1≤n≤10)。第二行是藥劑的種類m(0<m≤100)。

以下有m行,每行有n個數字用空格隔開,文件的第i+2行的n個數字中,如果第j個數為1,就表示第i種藥可以治愈病癥j(如果患有這種病的話則治愈,沒有這種病則無影響),如果為0表示無影響,如果為-1表示反而能使人得上這種病(無病患上,有病無影響)。Smart制的藥任何兩種性能都不同。

輸出描述 Output Description

你只要輸出用的最少的藥劑數就可以了,其實還有可能用盡了所有的藥也不能將所有病治愈,那樣的話你們只要輸出“The patient will be dead.”就可以了。

樣例輸入 Sample Input

3

2

1 0 1

-1 1 0

樣例輸出 Sample Output

2

數據範圍及提示 Data Size & Hint

1≤n≤10

0<m≤100

 

用dp[i]表示到達第i種狀態所需要的最小步數

 

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<queue>
 6 #include<algorithm>
 7 #define lli long long int 
 8 using namespace std;
 9 const int MAXN=1001;
10 const int maxn=0x7fffff;
11 inline void read(int &n)
12 {
13     char c='+';int x=0;bool flag=0;
14     while(c<'0'||c>'9')
15     {c=getchar();if(c=='-')flag=1;}
16     while(c>='0'&&c<='9')
17     {x=(x<<1)+(x<<3)+c-48;c=getchar();}
18     flag==1?n=-x:n=x;
19 }
20 int a[MAXN][MAXN];
21 int dp[MAXN];
22 int n,m;
23 int main()
24 {
25     read(n);read(m);
26     for(int i=1;i<=m;i++)
27         for(int j=1;j<=n;j++)
28             read(a[i][j]);
29     for(int i=0;i<=(1<<n);i++)
30         dp[i]=maxn;
31     dp[0]=0;
32     for(int i=0;i<=(1<<n);i++)
33     {
34         for(int j=1;j<=m;j++)
35         {
36             int now=i;
37             for(int k=1;k<=n;k++)
38             {
39                 if(a[j][k]==0)    continue;
40                 if(a[j][k]==1)    now=now|(1<<k-1);
41                 if(a[j][k]==-1&&now&(1<<k-1))    now^=(1<<k-1);    
42             }
43             dp[now]=min(dp[now],dp[i]+1);
44         }
45     }
46     if(dp[(1<<n)-1]==maxn)printf("The patient will be dead.\n");
47     else printf("%d\n",dp[(1<<n)-1]);
48     return 0;
49 }

 


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

-Advertisement-
Play Games
更多相關文章
  • function Pinyin($_String, $_Code='UTF8'){ //GBK頁面可改為gb2312,其他隨意填寫為UTF8 $_DataKey = "a|ai|an|ang|ao|ba|bai|ban|bang|bao|bei|ben|beng|bi|bian|biao|bie|b ...
  • "當系統的每一部分都由最優解或相對優解組成,那麼系統最終也將是最完美的。" 這句話是在參加莫技術分享會上聽到的,這句話吸引我占在人群後面聽完了她的分享,確實受益良多。 本文也旨在描述自己在項目演變中對一處公共處理邏輯優化的過程,周期略長最近有時間整理如下。 業務系統數據傳遞過程中,會抽取一些公共的屬 ...
  • 寫在前面: 用JDBC從資料庫中查詢數據要用到結果集ResultSet,其中我們在獲取結果的時候經常用到rs.next()方法來判斷是否查詢到了數據。 但是要特別註意,next()方法用一次,游標就往後移了一位,此時再使用next()來獲取結果就是結果集中的第二個記錄了。 舉例:這裡我就用偽代碼寫的 ...
  • 7.用戶輸入輸出和while迴圈 1、使用函數input()輸入,print()列印,字元串可以用逗號隔開。end=‘ ’ 關鍵字參數,列印時可以不換行,sep=‘ 你想要的分隔符 ’ ,關鍵字參數,替換掉預設的分隔字元串。 2、輸入是Input,輸出是Output,因此,我們把輸入輸出統稱為Inp ...
  • 一、定義一個類 第一種方法__init__()方法是一種特殊的方法,被稱為類的構造函數或初始化方法,當創建了這個類的實例時就會調用該方法 self 代表類的實例,self 在定義類的方法時是必須有的,雖然在調用時不必傳入相應的參數。 二、self代表的實例,而非類 類的方法與普通的函數只有一個特別的 ...
  • Java集合框架小應用之撲克牌小游戲 學習了Java集合框架之後,我寫了一個撲克牌小游戲來鞏固知識。學習之餘的練習之作,有不足之處還得多多指教了~(*/ω\*) 撲克牌小游戲背景: 1. 創建一副撲克牌,不考慮大小王 包括四種花色:黑桃、紅桃、梅花、方片 十三種點數:2-10,J Q K A 2. ...
  • 手頭現在有一份福布斯2016年全球上市企業2000強排行榜的數據,但原始數據並不規範,需要處理後才能進一步使用。 本文通過實例操作來介紹用pandas進行數據整理。 ...
  • 首先,萬分抱歉,據上一篇更新後,時隔已近一個月。雖然博主不日念起此事,但實在是最近繁事纏身,說這些也是想告訴對此文有所期待的朋友,博主一定會更完到最後一章,不盡人意之處,還請各位多擔待。如果不出意外,博主還是努力一周更兩篇。 前面,我們看過項目實際運行的功能介紹,表結構也有所瞭解。今天,我們就正式進 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...