HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
poj1050To the Max_最大子段和
題意:
求給定矩陣的最大子矩陣和。
先來回顧一下
一維的最大子段和問題:
給定一個序列a[n],求a[n]的最大子段和。
DP的遞推公式為b[j] = max{b[j - 1] + a[j], a[j]}. 其中b[j]表示a[n]中包含b[j]的最大子段和。時間復雜度為O(n)
對于二維矩陣而言,我們可以通過把多行壓縮(按列求和)成一行的方式將問題
轉換為一維
。
行壓縮時枚舉復雜度為O(N^2)。因此整個求解過程的時間復雜度為O(N^3)。
代碼
1
import
java.io.
*
;
2
import
java.util.
*
;
3
class
Main
4
{
5
6
public
static
void
main(String[] args)
7
{
8
9
Scanner sc
=
new
Scanner(System.in);
10
int
N;
11
N
=
sc.nextInt();
12
int
nums[][]
=
new
int
[N][N];
13
14
for
(
int
i
=
0
; i
<
N; i
++
)
15
{
16
for
(
int
j
=
0
; j
<
N; j
++
)
17
{
18
nums[i][j]
=
sc.nextInt();
19
}
20
}
21
int
ns[]
=
new
int
[N];
22
int
max
=
0
;
23
for
(
int
i
=
0
; i
<
N; i
++
)
//
begin row
24
{
25
for
(
int
j
=
i; j
<
N; j
++
)
//
end row
26
{
27
Arrays.fill(ns,
0
);
28
for
(
int
k
=
0
; k
<
N; k
++
)
//
get ns[]
29
{
30
for
(
int
ii
=
i; ii
<=
j; ii
++
)
31
{
32
ns[k]
+=
nums[ii][k];
33
}
34
}
35
int
t
=
thisMaxSum(ns);
36
if
(t
>
max)
37
max
=
t;
38
}
39
}
40
System.out.println(max);
41
}
42
private
static
int
thisMaxSum(
int
[] ns)
43
{
44
int
max
=
0
;
45
int
b
=
0
;
46
for
(
int
i
=
0
; i
<
ns.length; i
++
)
47
{
48
if
(b
+
ns[i]
>
ns[i])
49
b
+=
ns[i];
50
else
51
b
=
ns[i];
52
if
(b
>
max)
53
max
=
b;
54
}
55
return
max;
56
}
57
58
}
59
posted on 2013-04-17 15:32
小鼠標
閱讀(300)
評論(0)
編輯
收藏
引用
所屬分類:
Java基礎練習
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
編輯距離
閏年判斷
正則表達式簡單筆記
Excel格式地址轉換
一道模擬題——機器人行走距離計算
排列練習2
素數篩法
排列組合練習
排列組合
poj1068Parencodings
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標 Powered by:
博客園
模板提供:
滬江博客
<
2025年7月
>
日
一
二
三
四
五
六
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
9
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(111)
C語言(3)
DP(9)
Java筆記(1)
Java基礎練習(25)
安卓(1)
本科畢設(1)
博弈(1)
大數(7)
回溯(2)
排序(10)
暑期培訓周賽(3)
數據結構(7)
數論(1)
水題(8)
圖論(24)
網選訓練(8)
隨筆檔案
(127)
2014年3月 (1)
2013年7月 (10)
2013年5月 (1)
2013年4月 (11)
2013年3月 (8)
2012年10月 (1)
2012年9月 (12)
2012年8月 (38)
2012年7月 (14)
2012年6月 (2)
2012年5月 (8)
2012年4月 (6)
2012年3月 (6)
2012年2月 (4)
2011年8月 (5)
friends
陳鋼
大鵬
黨姐
焦林楓
汪濤
小白學長
媛姐
媛姐csdn
最新評論
1.?re: 線段樹
是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
加油,祝你好運啦!
--小鼠標
2.?re: 線段樹
對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網絡流
過來看看你。
--achiberx
4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
--Hang
5.?re: 快速排序、線性時間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調隊列(5499)
2.?Linux select()函數使用(3993)
3.?快速排序、線性時間選擇(3724)
4.?poj3468--絕對經典的線段樹題(3646)
5.?優先隊列--堆實現(3312)
久久www免费人成看国产片
|
av无码久久久久久不卡网站
|
久久久久国产一区二区三区
|
亚洲国产小视频精品久久久三级
|
少妇被又大又粗又爽毛片久久黑人
|
国产69精品久久久久久人妻精品
|
亚洲AV无码久久精品狠狠爱浪潮
|
精品九九久久国内精品
|
午夜福利91久久福利
|
久久精品无码免费不卡
|
国产69精品久久久久99尤物
|
久久精品视频网
|
99久久精品免费观看国产
|
精品少妇人妻av无码久久
|
7777久久久国产精品消防器材
|
日本久久中文字幕
|
久久国产AVJUST麻豆
|
一本一道久久a久久精品综合
|
亚洲国产成人久久综合区
|
久久久青草青青国产亚洲免观
|
久久国产香蕉一区精品
|
日本精品一区二区久久久
|
A级毛片无码久久精品免费
|
亚洲国产成人精品无码久久久久久综合
|
97久久国产亚洲精品超碰热
|
久久国产精品二国产精品
|
无码人妻久久一区二区三区蜜桃
|
久久人人爽人人澡人人高潮AV
|
狠狠色狠狠色综合久久
|
狠狠色婷婷综合天天久久丁香
|
欧美激情精品久久久久久
|
69国产成人综合久久精品
|
日日狠狠久久偷偷色综合0
|
狠狠狠色丁香婷婷综合久久五月
|
亚洲国产精品狼友中文久久久
|
一本伊大人香蕉久久网手机
|
久久狠狠爱亚洲综合影院
|
日韩欧美亚洲综合久久
|
青青草国产97免久久费观看
|
94久久国产乱子伦精品免费
|
久久精品国产亚洲av麻豆色欲
|