HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯(lián)系
管理
poj1050To the Max_最大子段和
題意:
求給定矩陣的最大子矩陣和。
先來回顧一下
一維的最大子段和問題:
給定一個序列a[n],求a[n]的最大子段和。
DP的遞推公式為b[j] = max{b[j - 1] + a[j], a[j]}. 其中b[j]表示a[n]中包含b[j]的最大子段和。時間復(fù)雜度為O(n)
對于二維矩陣而言,我們可以通過把多行壓縮(按列求和)成一行的方式將問題
轉(zhuǎn)換為一維
。
行壓縮時枚舉復(fù)雜度為O(N^2)。因此整個求解過程的時間復(fù)雜度為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
小鼠標(biāo)
閱讀(298)
評論(0)
編輯
收藏
引用
所屬分類:
Java基礎(chǔ)練習(xí)
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
編輯距離
閏年判斷
正則表達式簡單筆記
Excel格式地址轉(zhuǎn)換
一道模擬題——機器人行走距離計算
排列練習(xí)2
素數(shù)篩法
排列組合練習(xí)
排列組合
poj1068Parencodings
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標(biāo) Powered by:
博客園
模板提供:
滬江博客
<
2013年4月
>
日
一
二
三
四
五
六
31
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
1
2
3
4
5
6
7
8
9
10
11
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(111)
C語言(3)
DP(9)
Java筆記(1)
Java基礎(chǔ)練習(xí)(25)
安卓(1)
本科畢設(shè)(1)
博弈(1)
大數(shù)(7)
回溯(2)
排序(10)
暑期培訓(xùn)周賽(3)
數(shù)據(jù)結(jié)構(gòu)(7)
數(shù)論(1)
水題(8)
圖論(24)
網(wǎng)選訓(xùn)練(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
陳鋼
大鵬
黨姐
焦林楓
汪濤
小白學(xué)長
媛姐
媛姐csdn
最新評論
1.?re: 線段樹
是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準(zhǔn)真的不是自己的原因呢。
加油,祝你好運啦!
--小鼠標(biāo)
2.?re: 線段樹
對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網(wǎng)絡(luò)流
過來看看你。
--achiberx
4.?re: (轉(zhuǎn))ubuntu11.10無法啟動無線網(wǎng)絡(luò)的解決方法
膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區(qū)域賽難道是ACM區(qū)域賽。。?
--Hang
5.?re: 快速排序、線性時間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區(qū)基準(zhǔn)在數(shù)組中重復(fù)的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調(diào)隊列(5497)
2.?Linux select()函數(shù)使用(3990)
3.?快速排序、線性時間選擇(3719)
4.?poj3468--絕對經(jīng)典的線段樹題(3642)
5.?優(yōu)先隊列--堆實現(xiàn)(3309)
一本色综合网久久
|
精品久久久无码中文字幕天天
|
免费精品久久久久久中文字幕
|
国内精品久久久久影院老司
|
久久久久亚洲AV成人网人人网站
|
久久久国产打桩机
|
久久福利青草精品资源站
|
人妻中文久久久久
|
国产精品久久久久久福利漫画
|
久久久久久久综合综合狠狠
|
性做久久久久久久
|
色偷偷88欧美精品久久久
|
成人资源影音先锋久久资源网
|
久久久无码精品亚洲日韩软件
|
久久综合给久久狠狠97色
|
久久久久久综合网天天
|
久久精品国产免费
|
国产A级毛片久久久精品毛片
|
亚洲午夜久久影院
|
jizzjizz国产精品久久
|
超级97碰碰碰碰久久久久最新
|
91精品国产综合久久香蕉
|
精品久久久久久久无码
|
久久久久久A亚洲欧洲AV冫
|
欧美久久久久久
|
久久久精品波多野结衣
|
热久久国产精品
|
久久精品国产一区二区三区日韩
|
亚洲精品乱码久久久久久久久久久久
|
国内精品九九久久久精品
|
亚洲av成人无码久久精品
|
人人妻久久人人澡人人爽人人精品
|
久久久91人妻无码精品蜜桃HD
|
国内精品久久久久久久涩爱
|
国产精品午夜久久
|
精品综合久久久久久88小说
|
久久97久久97精品免视看秋霞
|
青青青青久久精品国产h
|
久久97久久97精品免视看秋霞
|
久久久免费观成人影院
|
亚洲欧美国产精品专区久久
|