2853 方格游戲(三維棋盤)

来源:http://www.cnblogs.com/zwfymqz/archive/2017/06/29/7096449.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

菜菜看到了一個游戲,叫做方格游戲~

游戲規則是這樣的:

在一個n*n的格子中,在每個1*1的格子里都能獲得一定數量的積分獎勵,記左上角為(1,1),右下角為(n,n)。游戲者需要選擇一條(1,1)到(n,n)的路徑,並獲得路徑上獎勵的積分。對於路徑當然也有要求啦,要求是只能往坐標變大的方向走【從(x,y)到(x+1,y)或者(x,y+1)】,走過2n-1個區域到達(n,n)。當然,獲得的積分最高的就能取勝啦。

這時,菜菜看到了他的好友月月,於是邀請她來玩雙人版的。雙人版的規則就是在單人版的基礎上加上一條兩人的路線不能相同。月月知道菜菜的很聰明,怕輸得太慘,就不太願意和他玩。菜菜可慌了,於是定義了一個公平值D,這個公平值等於倆人所選擇的路徑所能獲得的積分一一對應相減的差的絕對值之和,即D=sigma (|kxi-kyi|)|(kx,ky分別為菜菜,月月走過的每一個區域的叢林繫數)。不過這可是個龐大的計算任務,菜菜找到了你,請你幫忙計算公平值的最大值。

輸入描述 Input Description

    第一行,一個正整數n

    接下來的n行,每行n個整數,表示叢林中每個區域的公平值

輸出描述 Output Description

一個整數Dmax,即公平值的最大值

樣例輸入 Sample Input

4

1 2 3 4

1 5 3 2

8 1 3 4

3 2 1 5

樣例輸出 Sample Output

13

數據範圍及提示 Data Size & Hint

對於20%的數據,保證0<n≤20

對於50%的數據,保證0<n≤50

對於100%的數據,保證0<n≤100且對於所有的i,j保證|Kij|≤300

 

首先這題四維會爆空間。

所以就學了一下用三維表示。

 

前提:

1.設兩個人的坐標分別為A,B;

2.n*n的方格,從(1,1)點到(n,n)點需要的總步數為2*n+1(n個橫,n個列,其中有一個重覆)

 

 

我們用k來表示步數

我們用i來表示在第k步A的橫坐標為i

       用j來表示在第k步B的橫坐標為j

那麼A的坐標可以表示為(i,k-i+1)

       B的坐標可以表示為(j,k-j+1)

對於每一個點(i,j)

同樣有四中情況轉移而來

1.A從上到下    dp[i-1][j][k-1]

2.B從上到下    dp[i][j-1][k-1]

3.AB同時從上到下dp[i-1][j-1][k-1]

4.AB同時從左往右dp[i][j][k-1]

 

然後再加上這個點的值就好

 

 

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<cstdlib>
 6 using namespace std;
 7 void read(int &n)
 8 {
 9     char c='+';int x=0;bool flag=0;
10     while(c<'0'||c>'9')
11     {c=getchar();if(c=='-')flag=1;}
12     while(c>='0'&&c<='9')
13     {x=x*10+(c-48);c=getchar();}
14     flag==1?n=-x:n=x;
15 }
16 int n;
17 int dp[101][101][301];
18 int a[101][101];
19 int ans=0;
20 int main()
21 {
22     read(n);
23     for(int i=1;i<=n;i++)
24         for(int j=1;j<=n;j++)
25             read(a[i][j]);
26     // a :(i,k-i+1)
27     // b :(j,k-j+1)
28     for(int k=1;k<=2*n-1;k++)
29     {
30         for(int i=1;i<=n&&i<=k;i++)
31             for(int j=1;j<=n&&j<=k;j++)
32             {
33                 dp[i][j][k]=max(dp[i-1][j][k-1],dp[i][j][k]);
34                 dp[i][j][k]=max(dp[i][j-1][k-1],dp[i][j][k]);
35                 dp[i][j][k]=max(dp[i-1][j-1][k-1],dp[i][j][k]);
36                 dp[i][j][k]=max(dp[i][j][k-1],dp[i][j][k]);
37                 dp[i][j][k]+=abs(a[i][k-i+1]-a[j][k-j+1]);
38             }
39     }
40     printf("%d",dp[n][n][2*n-1]);
41     return 0;
42 }

 

 

 

 

 

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、說明 與@Component註解功能相同,但意義不同的註解還有三個: 1)@Repository:註解在Dao實現類上 2)@Service:註解在Service實現類上 3)@Controller:註解在SpringMVC的處理器上 Bean作用域: @Scope("prototype"):用 ...
  • Python中的可變對象和不可變對象 什麼是可變/不可變對象 不可變對象,該對象所指向的記憶體中的值不能被改變。 當改變某個變數時候,由於其所指的值不能被改變,相當於把原來的值複製一份後再改變,這會開闢一個新的地址,變數再指向這個新的地址。 可變對象,該對象所指向的記憶體中的值可以被改變。 變數(準確的 ...
  • /* 選擇工廠和更新工廠模式,這個模式的類(UpdateFactory和SelectionFactory類)就是用來創建SQL語句的. 因為涉及到之前學習的內容比較多,這裡就儘量將之前相關模式的示例代碼放在一起來進行學習和回顧了。 以下的代碼都是代碼片段而且涉及到連接資料庫,無法進行整體的調試(某些... ...
  • 動態規劃的演算法題往往都是各大公司筆試題的常客。在不少演算法類的微信公眾號中,關於“動態規劃”的文章屢見不鮮,都在試圖用最淺顯易懂的文字來描述講解動態規劃,甚至有的用漫畫來解釋,認真讀每一篇公眾號推送的文章實際上都能讀得懂,都能對動態規劃有一個大概瞭解。 什麼是動態規劃?通俗地理解來說,一個問題的解決辦 ...
  • 這是我寫的登陸註冊界面,使用tkinter,可以實現簡單的登陸和註冊賬號,使用的主要是Label,Entry和Button組件。 ...
  • 一、JavaCC JavaCC是java的compiler compiler。JavaCC是LL解析器生成器,可處理的語法範圍比較狹窄,但支持無限長的token超前掃描。 安裝過程: 我是從github上down下來的zip壓縮包,然後安裝了下ant, 然後通過ant安裝的javacc 1. 首先下 ...
  • 首先辨析“/”與“\” window中的路徑一般用“\”; java中的路徑一般用“/”;如果用“\”需要對其轉義成“\\” 1、絕對路徑 以根目錄作為參考點的的文件或文件夾所在的路徑,是硬碟上的真實路徑。具有唯一性的特點。 例如:C:\caosiege\python\project\C.py,代表 ...
  • 題目描述 設G為有n個頂點的有向無環圖,G中各頂點的編號為1到n,且當為G中的一條邊時有i < j。設w(i,j)為邊的長度,請設計演算法,計算圖G中<1,n>間的最長路徑。 輸入輸出格式 輸入格式: 輸入文件longest.in的第一行有兩個整數n和m,表示有n個頂點和m條邊,接下來m行中每行輸入3 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...