Coloring Trees CodeForces - 711C

来源:http://www.cnblogs.com/hehe54321/archive/2017/09/13/cf-711c.html
-Advertisement-
Play Games

Coloring Trees CodeForces - 711C 題意:有n個點,每個點有一個c值,如果為0表示它沒有被染色,否則表示它被染成了c值的顏色。顏色有1到m。把第i棵樹染成顏色j所需要的代價是p[i][j]。求最小的代價,使得將每棵樹都染色,且如果將連續的一串同色的樹視為一個集合,共有k ...


Coloring Trees CodeForces - 711C

題意:有n個點,每個點有一個c值,如果為0表示它沒有被染色,否則表示它被染成了c值的顏色。顏色有1到m。把第i棵樹染成顏色j所需要的代價是p[i][j]。求最小的代價,使得將每棵樹都染色,且如果將連續的一串同色的樹視為一個集合,共有k個集合。輸出代價,如果不可能達到要求輸出-1。

方法:

$ans[i][j][k]$表示把前i棵樹染好,並且最後一種顏色是j,並且總共有k段的最小費用。

首先初始化ans全部值為一個很大的樹(方便min),然後$ans[0][1..m][0]=0$

c[i]=0時:更新每個j

$ans[i][j][k]=min(ans[i-1][j][k]+p[i][j],min\{ans[i-1][q][k-1]+p[i][j] | 1<=q<=m\})$

也就是$ans[i][j][k]=min(ans[i-1][j][k],min\{ans[i-1][q][k-1] | 1<=q<=m\})+p[i][j]$

c[i]=1時:只更新$j=c[i]$
$ans[i][j][k]=min(ans[i-1][j][k],min\{ans[i-1][q][k-1] | 1<=q<=m\})$

註意:i=1也就是第一棵樹需要特判。可以在迴圈裡加條件/在0加值/把第一棵樹拉出來單獨處理。

 1 #include<cstdio>
 2 #include<cstring>
 3 typedef long long LL;
 4 LL ans[101][101][101];
 5 LL p[101][101];
 6 LL c[101];
 7 LL n,m,k2,minans=0x3f3f3f3f3f3f3f3f;
 8 LL min(LL a,LL b)
 9 {
10     return a>b?b:a;
11 }
12 int main()
13 {
14     LL i,j,k,q;
15     scanf("%I64d%I64d%I64d",&n,&m,&k2);
16     for(i=1;i<=n;i++)
17         scanf("%I64d",&c[i]);
18     for(i=1;i<=n;i++)
19         for(j=1;j<=m;j++)
20             scanf("%I64d",&p[i][j]);
21     memset(ans,0x3f,sizeof(ans));
22     for(i=1;i<=m;i++)
23         ans[0][i][0]=0;
24     for(i=1;i<=n;i++)
25     {
26         if(c[i]==0)
27         {
28             for(j=1;j<=m;j++)
29                 for(k=1;k<=k2;k++)
30                 {
31                     ans[i][j][k]=ans[i-1][j][k];
32                     for(q=1;q<=m;q++)
33                         if(q!=j||i==1)
34                             ans[i][j][k]=min(ans[i][j][k],ans[i-1][q][k-1]);
35                     ans[i][j][k]+=p[i][j];
36                 }
37         }
38         else
39         {
40             j=c[i];
41             for(k=1;k<=k2;k++)
42             {
43                 ans[i][j][k]=ans[i-1][j][k];
44                 for(q=1;q<=m;q++)
45                     if(q!=j||i==1)
46                         ans[i][j][k]=min(ans[i][j][k],ans[i-1][q][k-1]);
47             }
48         }
49     }
50     for(i=1;i<=m;i++)
51         minans=min(ans[n][i][k2],minans);
52     if(minans==0x3f3f3f3f3f3f3f3f)
53         printf("-1");
54     else
55         printf("%I64d",minans);
56     return 0;
57 }

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

-Advertisement-
Play Games
更多相關文章
  • 官方手冊地址:http://effbot.org/imagingbook/image.htm Image模塊 圖像模塊提供了一個具有相同名稱的類,用於表示一個PIL的圖像。該模塊還提供了許多功能,包括載入圖片文件函數和創建新的圖像函數。 模塊示例: 下麵的程式載入一個圖像,再旋轉45度,並使用一個外 ...
  • 簡單的BBS論壇 實現功能 git倉庫地址: https://github.com/uge3/BBS 1、整體參考“抽屜新熱榜” + “博客園” 2、實現不同論壇版塊 3、帖子列表展示 4、個人博客主頁 5、個人博客標簽、分類、時間 篩選 6、帖子評論數、點贊數展示 7、允許登錄用戶發貼、評論、點贊 ...
  • redis筆記 下載完redis,執行make命令。 然後啟動redis就進src文件夾,執行./redis-server就可以了。 再在文件夾下執行 ./redis-cli 就可以執行redis的命令了。 pipelining 一次請求發送多個命令,以提高性能。我們在使用redis時都是向它發送命 ...
  • 拼接: name=zhuhuan age=23 salary=333 info=''' info of %s age:%s name:%s salary:%s %(name,age,name,salary) ''' info2=''' info of {_name} age:{_age} name: ...
  • JPA基礎及查詢規則 JPA JPA是Java Persistence API的簡稱,中文名Java持久層API,是JDK 5.0註解或XML描述對象-關係表的映射關係,並將運行期的實體對象持久化到資料庫中。 JPA框架中支持大數據集、事務、併發等容器級事務,這使得 JPA 超越了簡單持久化框架的局 ...
  • 1.減少可調用對象的參數個數,使用functools.partial凍結參數 使用functools.partial(),可以固定一個或者多個值,減少調用參數。 2.給函數參數增加元信息 函數聲明中的各個參數可以在 : 之後增加註解表達式。如果參數有預設值,註解放在參數名和 = 號之間。如果想註解返 ...
  • package com.swift; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja... ...
  • 承接【Spring事務管理】,上一篇我們已經簡單接觸了關於Spring jdbc的知識,今天我們承接上一篇進行一下補充,上一篇直接將dataSource註入到了Dao層進行了實現,本篇我們通過簡單進行一下補充,將另外兩種實現為大家進行一下演示:1、在自己定義的DAO 實現類中註入一個DataSour ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...