poj 1015 Jury Compromise

来源:https://www.cnblogs.com/PowerofChoas/archive/2017/12/28/8128199.html
-Advertisement-
Play Games

題目大意:每個人有兩種值Di和Pi,從n個人中選m個人組成集合J,D(J)和P(J)為這m個人的Di與Pi和,使|D(J) - P(J)|最小。若有多個集合J最小,則使D(J) + P(J) 最大。 1<=n<=200, 1<=m<=20 ,Di和Pi最大為20. 註意到Di和Pi的和很小,我們可以 ...


題目大意:每個人有兩種值Di和Pi,從n個人中選m個人組成集合J,D(J)和P(J)為這m個人的Di與Pi和,使|D(J) - P(J)|最小。若有多個集合J最小,則使D(J) + P(J) 最大。

1<=n<=200, 1<=m<=20 ,Di和Pi最大為20.

註意到Di和Pi的和很小,我們可以用類似背包的思想將所有可能生成的值記錄下來。

路徑用數組記錄,每次加入節點時加入本節點與之前的路徑。

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<cstdlib>
 4 #define MAXM (20 + 5)
 5 #define MAXN (200 + 5)
 6 #define MAXDP (20 * 20 + 5)
 7 int dp[MAXM][MAXDP], path[MAXM][MAXDP][MAXM];
 8 int i, cas;
 9 int d[MAXN], p[MAXN], plu[MAXN], subs[MAXN];
10 int main() {
11     int n, m;
12     while(scanf("%d%d", &n, &m) && n && m){
13         printf("Jury #%d\n", ++cas);
14         for(i = 0; i < n; i++){
15             scanf("%d%d", &d[i], &p[i]);
16             plu[i] = d[i] + p[i];
17             subs[i] = d[i] - p[i];
18         }
19         int fix = 20 * m;
20         memset(dp, -1, sizeof(dp)); 
21         memset(path, 0, sizeof(path));
22         dp[0][fix] = 0;
23         for(int k = 0; k < n; k++)
24             for(i = m - 1; i >= 0; i--) // attention
25                 for(int j = 0; j <= fix * 2; j++)
26                     if(dp[i][j] >= 0){ 
27                         if(dp[i + 1][j + subs[k]] < dp[i][j] + plu[k]){
28                             dp[i + 1][j + subs[k]] = dp[i][j] + plu[k]; // 記錄相同差值的最大和
29                             for(int t = 0; t < i; t++) 
30                                 path[i + 1][j + subs[k]][t] = path[i][j][t]; // 枚舉之前的路徑
31                             path[i + 1][j + subs[k]][t]=k; // 當前節點
32                         }
33                     }
34 
35         for(i = 0; dp[m][fix + i] == -1 && dp[m][fix - i] == -1; i++); // 枚舉最小差的絕對值
36         int temp = dp[m][fix + i] > dp[m][fix - i] ? i : -i; 
37         int sumd = (dp[m][fix + temp] + temp) / 2;
38         int sump = (dp[m][fix + temp] - temp) / 2;
39         printf("Best jury has value %d for prosecution and value %d for defence:\n", sumd, sump);
40         for(i = 0; i < m; i++) 
41             printf(" %d",path[m][fix + temp][i] + 1);
42         printf("\n");
43     }
44 }

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 1、安裝3個zookeeper 1.1創建集群安裝的目錄 1.2配置一個完整的服務 這裡不做詳細說明,參考我之前寫的 zookeeper單節點安裝 進行配置即可,此處直接複製之前單節點到集群目錄 創建數據文件目錄 在數據文件目錄下添加myid文件 從數字1開始 保存退出,查看是否添加成功 修改zk1 ...
  • 設計模式-模板方法模式(Template Method Pattern) 2.1 定義 定義一個操作中演算法的框架,將一些步驟延遲到子類中去操作,使得子類可以不改變結構就可以改變一些特定的步驟. 模板方法模式很簡單.就只是使用了一個繼承(extends),其中abstractClass 叫做抽象模板. ...
  • 一、無所不在的連接 針對不通的使用場景,無線網路技術有很多種。 鑒於無線網路技術如此多樣,籠統地概括所有無線網路的性能優化手段是不可能的。好在大多數無線技術的原理都是相通的,衡量性能的指標和約束條件也具有普遍實用性。只要把影響無線性能的基本原理搞清楚,那其他問題自然也就迎刃而解了。 二、無線網路的性 ...
  • 1、安裝jdk 2、安裝解壓zookeeper 先創建文件夾 解壓zookeeper壓縮包 3、 創建配置文件zoo.cfg 4、運行測試 ...
  • JEEPlatform 一款企業信息化開發基礎平臺,可以用於快速構建企業後臺管理系統,集成了OA(辦公自動化)、SCM(供應鏈系統)、ERP(企業資源管理系統)、CMS(內容管理系統)、CRM(客戶關係管理系統)等企業系統的通用業務功能。Github鏈接:https://github.com/u01 ...
  • 咖啡店需要做一個訂單系統,以合乎飲料供應要求。 1.最初是這樣設計的: 每一種飲料都需要繼承該抽象類,並覆寫cost()方法。 2.但是購買咖啡時需要考慮到調料的部分,每種咖啡會加不同種的調料,比如蒸奶、豆漿、摩卡或者覆蓋奶泡,那麼訂單系統需要考慮加入不同調料後的價格。因此需要實現不同的子類來定義添 ...
  • In Campaign mode, you can check your strategies on already defeated bases. You will not lose your troops.在戰役模式中,你能查看已被打敗的玩家的塔防策略,而且你不會損失任何戰鬥單位。Let's w ...
  • JAVA中的異常類都繼承自Throwable類,也就是說,這是異常類的根。Throwable類擴展了兩個類Error類和Exception類,Exception類又擴展了一個RuntimeException類。如下圖: Error:稱為錯誤,由Java虛擬機生成並拋出,這類錯誤一般是運行時系統內部的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...