洛谷P1437 [HNOI2004]敲磚塊(dp)

来源:https://www.cnblogs.com/zwfymqz/archive/2018/07/08/9280698.html
-Advertisement-
Play Games

題目背景 無 題目描述 在一個凹槽中放置了 n 層磚塊、最上面的一層有n 塊磚,從上到下每層依次減少一塊磚。每塊磚 都有一個分值,敲掉這塊磚就能得到相應的分值,如下圖所示。 如果你想敲掉第 i 層的第j 塊磚的話,若i=1,你可以直接敲掉它;若i>1,則你必須先敲掉第 i-1 層的第j 和第j+1 ...


題目背景

題目描述

在一個凹槽中放置了 n 層磚塊、最上面的一層有n 塊磚,從上到下每層依次減少一塊磚。每塊磚

都有一個分值,敲掉這塊磚就能得到相應的分值,如下圖所示。

14 15  4  3  23
 33  33 76  2
   2   13 11
     22 23
       31

如果你想敲掉第 i 層的第j 塊磚的話,若i=1,你可以直接敲掉它;若i>1,則你必須先敲掉第

i-1 層的第j 和第j+1 塊磚。

你現在可以敲掉最多 m 塊磚,求得分最多能有多少。

輸入輸出格式

輸入格式:

 

輸入文件的第一行為兩個正整數 n 和m;接下來n 行,描述這n 層磚塊上的分值a[i][j],滿足

0≤a[i][j]≤100。

對於 100%的數據,滿足1≤n≤50,1≤m≤n*(n+1)/2;

 

輸出格式:

 

輸出文件僅一行為一個正整數,表示被敲掉磚塊的最大價值總和。

 

輸入輸出樣例

輸入樣例#1: 複製
4 5
2 2 3 4
8 2 7
2 3
49
輸出樣例#1: 複製
19

 

 

 

非常妙的一道題目

首先我們最先想到的肯定是$f[i][j][k]$表示第$i$行第$j$列選了$k$個的最大價值

但是這樣由於第一行的緣故是有後效性的

轉換一下思路,用$f[i][j][k]$表示第$i$列,第$i$個,選了$k$

轉移的時候倒著枚舉列,這樣就不會有後效性了

 

 

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
//#define int long long 
using namespace std;
const int MAXN = 1e5 + 10, INF = 1e9 + 10;
inline int read() {
    char c = getchar(); int x = 0, f = 1;
    while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
    while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return x * f;
}
int N, M, f[51][51][5001], a[5001][5001]; 
main() { 
#ifdef WIN32
    //freopen("a.in", "r", stdin);
#endif
    N = read(); M = read();
    for(int i = 1; i <= N; i++) 
        for(int j = 1; j <= N - i + 1; j++)
            a[i][j] = read();
    memset(f, -0x3f, sizeof(f));
    f[N + 1][0][0] = 0;
    for(int j = N; j >= 1; j--) {
        int sum = 0;
        for(int i = 0; i <= N - j + 1; i++, sum += a[i][j]) 
            for(int k = i; k <= M; k++) {
                for(int l = max(0, i - 1); l <= N - j; l++)
                    f[j][i][k] = max(f[j][i][k], f[j + 1][l][k - i] + sum);
            }
    }
    int ans = 0;
    for(int i = 1; i <= N; i++) 
        for(int j = 1; j <= N - i + 1; j++)
            ans = max(ans, f[i][j][M]);
    printf("%d", ans);
    return 0;
} 

 


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

-Advertisement-
Play Games
更多相關文章
  • Description 給定一個含有n個數的序列a[1],a[2],a[3]……a[n],程式必須回答這樣的詢問:對於給定的i,j,k,在a[i],a[i+1 ],a[i+2]……a[j]中第k小的數是多少(1≤k≤j-i+1),並且,你可以改變一些a[i]的值,改變後,程式還能針對改 變後的a繼續 ...
  • 前言 微服務概念已經非常流行,這影響了現在架構的思想潮流。 如今,使用spring cloud體系搭建微服務架構的公司越來越多,成本低,出線上產品快,模塊全,開源等原因未來可能更加流行。 一般,我們需要一個監控系統來監控應用的數據,比如記憶體,磁碟,線程情況,資料庫連接池,配置信息,jvm信息等等。 ...
  • 大家好,上篇文章為大家介紹了線程間通信和協作的一些基本方式,那這篇文章就來介紹一下經典的wait-notify機制吧。 什麼是wait-notify機制? 想象一下有兩個線程A、B,如果業務場景中需要這兩個線程交替執行任務(比如A執行完一次任務後換B執行,B執行完後再換A執行這樣重覆交替),之前的基 ...
  • 轉自:https://www.cnblogs.com/Lynn-Zhang/p/5377024.html C/C++程式編譯流程(預處理->編譯->彙編->鏈接) 程式的基本流程如圖: 1. 預處理 預處理相當於根據預處理指令組裝新的C/C++程式。經過預處理,會產生一個沒有巨集定義,沒有條件編譯指令 ...
  • 一、概念 先來整體的介紹一下這篇博文要介紹的幾個概念(Channel、ChannelHandler、ChannelPipeline、ChannelHandlerContext、ChannelPromise): Channel:Netty 中傳入或傳出數據的載體;ChannelHandler:Nett ...
  • Description 對於任何正整數x,其約數的個數記作g(x)。例如g(1)=1、g(6)=4。如果某個正整數x滿足:g(x)>g(i) 0<i<x ,則稱x為反質數。例如,整數1,2,4,6等都是反質數。現在給定一個數N,你能求出不超過N的最大的反質數麽 ? 對於任何正整數x,其約數的個數記作 ...
  • 引言 古人雲:“活到老,學到老。”互聯網算是最辛苦的行業之一,“加班”對工程師來說已是“家常便飯”,同時互聯網技術又日新月異,很多工程師都疲於應付,叫苦不堪。以至於長期以來流傳一個很廣的誤解:35歲是程式員工作的終點。 如何在繁忙的工作中做好技術積累,構建個人核心競爭力,相信是很多工程師同行都在思考 ...
  • 什麼是 Spring MVC 學習某一樣東西之前,我們一定要大致知道這個東西是什麼,能幹什麼,為什麼要用它。 Spring MVC 是一個開源平臺,一個基於 Spring 的 MVC 框架,它支持基於 Java 開發 Web 應用程式。MVC 架構很利於開發靈活、低耦合的 Web 應用程式組件。 M ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...