HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
poj1088滑雪
題意:找出矩陣中的最長下降序列的長度。
解題思路:
1.回溯,時間復雜度,指數級別。這是一種很容易想到的做法,不過會超時。
2.動態規劃,時間復雜度O(N^2)。相信我們都學過一維的
最長上升子序列
問題,這一題是一維的變形,我們只需稍加轉換就可以轉換為一維的。
先來回想一下一維的最長上升子序列的做法:對一個給定的節點p,我們只需枚舉p前面的所有節點的最長上升子序列的長度,用p前面的節點的長度去試圖更新p的長度即可。
我們如何將本題轉化為一維的問題呢?我們只需將矩陣中的所有點按照他的high排序,然后按照一維的處理即可。只不過p前面的節點在更新p時還要考慮他們在矩陣中的相對位置,因為只有跟p相鄰的四個點才有可能去更新p點的長度。
代碼
1
import
java.io.
*
;
2
import
java.util.
*
;
3
class
Main
4
{
5
private
static
int
R, C;
6
private
static
MyNode[] nds
=
new
MyNode[
110
*
110
];
7
public
static
void
main(String[] args)
8
{
9
10
Scanner sc
=
new
Scanner(System.in);
11
R
=
sc.nextInt();
12
C
=
sc.nextInt();
13
int
count
=
0
;
14
for
(
int
i
=
0
; i
<
R; i
++
)
15
{
16
for
(
int
j
=
0
; j
<
C; j
++
)
17
{
18
int
h
=
sc.nextInt();
19
nds[count
++
]
=
new
MyNode(i, j, h);
20
}
21
}
22
Arrays.sort(nds,
0
, count);
23
//
/
24
//
for(int i = 0; i < count; i++)
25
//
System.out.println("::" + nds[i].getH());
26
//
27
int
lens[][]
=
new
int
[R][C];
28
for
(
int
i
=
0
; i
<
R; i
++
)
29
Arrays.fill(lens[i],
1
);
30
for
(
int
i
=
1
; i
<
count; i
++
)
31
{
32
for
(
int
j
=
0
; j
<
i; j
++
)
33
{
34
int
r2
=
nds[i].getR();
35
int
c2
=
nds[i].getC();
36
int
h2
=
nds[i].getH();
37
38
int
r1
=
nds[j].getR();
39
int
c1
=
nds[j].getC();
40
int
h1
=
nds[j].getH();
41
if
(Math.abs(r2
-
r1)
+
Math.abs(c1
-
c2)
==
1
&&
h2
>
h1
42
&&
lens[r2][c2]
<=
lens[r1][c1])
43
{
44
lens[r2][c2]
=
lens[r1][c1]
+
1
;
45
}
46
}
47
}
48
int
max
=
0
;
49
for
(
int
i
=
0
; i
<
R; i
++
)
50
{
51
for
(
int
j
=
0
; j
<
C; j
++
)
52
if
(lens[i][j]
>
max)
53
max
=
lens[i][j];
54
}
55
System.out.println(max);
56
}
57
58
}
59
class
MyNode
implements
Comparable
<
MyNode
>
60
{
61
private
int
r;
62
private
int
c;
63
private
int
h;
64
public
MyNode(
int
r,
int
c,
int
h)
65
{
66
this
.r
=
r;
67
this
.c
=
c;
68
this
.h
=
h;
69
}
70
public
int
getR()
71
{
72
return
r;
73
}
74
public
int
getC()
75
{
76
return
c;
77
}
78
public
int
getH()
79
{
80
return
h;
81
}
82
public
int
compareTo(MyNode n2)
83
{
84
return
h
-
n2.h;
85
}
86
}
posted on 2013-04-16 18:36
小鼠標
閱讀(407)
評論(0)
編輯
收藏
引用
所屬分類:
Java基礎練習
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
編輯距離
閏年判斷
正則表達式簡單筆記
Excel格式地址轉換
一道模擬題——機器人行走距離計算
排列練習2
素數篩法
排列組合練習
排列組合
poj1068Parencodings
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標 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基礎練習(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.?單調隊列(5497)
2.?Linux select()函數使用(3990)
3.?快速排序、線性時間選擇(3719)
4.?poj3468--絕對經典的線段樹題(3642)
5.?優先隊列--堆實現(3309)
亚洲国产天堂久久综合
|
久久久国产精品亚洲一区
|
亚洲国产另类久久久精品小说
|
亚洲AV成人无码久久精品老人
|
久久久久免费精品国产
|
国产精品久久久久久福利漫画
|
久久国产成人午夜AV影院
|
久久水蜜桃亚洲av无码精品麻豆
|
无码精品久久久久久人妻中字
|
色综合久久无码中文字幕
|
婷婷久久综合九色综合98
|
91精品国产高清久久久久久91
|
久久精品国产黑森林
|
狠狠干狠狠久久
|
av国内精品久久久久影院
|
亚洲中文字幕无码久久精品1
|
日本久久中文字幕
|
精品无码人妻久久久久久
|
波多野结衣久久
|
区久久AAA片69亚洲
|
久久精品99久久香蕉国产色戒
|
亚洲AV无一区二区三区久久
|
久久99精品国产麻豆宅宅
|
人妻中文久久久久
|
久久青草国产精品一区
|
亚洲精品tv久久久久久久久
|
久久丝袜精品中文字幕
|
看全色黄大色大片免费久久久
|
久久天天躁狠狠躁夜夜avapp
|
久久久久亚洲av成人网人人软件
|
亚洲精品无码久久久久去q
|
亚洲国产成人精品91久久久
|
99久久无码一区人妻a黑
|
久久精品国产乱子伦
|
伊人久久无码精品中文字幕
|
久久精品国产一区二区三区不卡
|
国内精品久久久久久99蜜桃
|
久久人人爽人人爽人人AV东京热
|
综合久久给合久久狠狠狠97色
|
潮喷大喷水系列无码久久精品
|
天天躁日日躁狠狠久久
|