日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

AcWing 1068. 环形石子合并

發布時間:2023/12/3 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 AcWing 1068. 环形石子合并 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

AcWing 1068. 環形石子合并

題意:

n堆石頭圍成一個圈,然后將相鄰兩堆合并成新的一堆,得分為新的一堆的石頭數
問最高得分合最低得分

題解:

很簡單,區間dp的模板題
和這個題一樣
狀態轉移方程:
dpmax[i][j] = max(dp[i][k]+dp[k+1][j]+sum[j]-sum[i-1])
dpmin[i][j]=min(dp[i][k]+dp[k+1][j])+sum[j]-sum[i-1]
因為題目說的是環形,所以數組復制一倍
馬上要java期末考試,所以用java練練

代碼:

import java.io.*; import java.util.*;class Main{static BufferedReader read = new BufferedReader(new InputStreamReader(System.in));static int N = 410, INF = 0X3f3f3f3f;static int[] a = new int[N], sum = new int[N];static int[][] dpMax = new int[N][N];static int[][] dpMin = new int[N][N];public static void main(String[] args) throws Exception{int n = Integer.valueOf(read.readLine());String[] ss = read.readLine().split(" ");for(int i = 1; i <= ss.length; i++){a[i] = Integer.valueOf(ss[i - 1]);a[i + n] = Integer.valueOf(ss[i - 1]);}for(int i = 1; i <= 2 * n; i++){sum[i] = sum[i - 1] + a[i];Arrays.fill(dpMax[i], -INF);Arrays.fill(dpMin[i], INF);}for(int len = 1; len <= n; len++){for(int i = 1; i + len - 1 <= 2 * n; i++){int j = i + len - 1;if(len == 1) {dpMax[i][j] = dpMin[i][j] = 0;}else{for(int k = i; k < j; k++){dpMax[i][j] = Math.max(dpMax[i][j], dpMax[i][k] + dpMax[k + 1][j] + sum[j] - sum[i - 1]);dpMin[i][j] = Math.min(dpMin[i][j], dpMin[i][k] + dpMin[k + 1][j] + sum[j] - sum[i - 1]);}}}}int max = -INF, min = INF;for(int left = 1; left <= n; left++){max = Math.max(max, dpMax[left][left + n - 1]);min = Math.min(min, dpMin[left][left + n - 1]);}System.out.println(min);System.out.println(max);}}

總結

以上是生活随笔為你收集整理的AcWing 1068. 环形石子合并的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。