青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
poj1021_2D-Nim
題意:對比連個圖是否相同。相同的條件是A圖中每個連通的區域都在B圖中有一塊相同的區域與之對應。經過旋轉后對應也可以。
解題思路:
思路一:暴力式。遍歷并存儲A圖中所有聯通的區域,然后在B中逐個尋找與之對應的圖形。
思路二:等價轉化式。比較兩個圖中對應點的“連通度”是否相同。相同輸出YES。空白點的連通度為0,空白點的連通度為它所在行和列與之相連的非空白點的個數。
方式二非常巧妙,將二維問題轉化為了一維問題,大大簡化了問題。
代碼
1
import
java.io.
*
;
2
import
java.util.
*
;
3
class
Main
4
{
5
private
static
int
[][] map1
=
new
int
[
110
][
110
];
6
private
static
int
[][] map2
=
new
int
[
110
][
110
];
7
private
static
CountNode[] ctnd1
=
new
CountNode[
110
*
110
];
8
private
static
CountNode[] ctnd2
=
new
CountNode[
110
*
110
];
9
private
static
int
col;
10
private
static
int
row;
11
public
static
void
main(String[] args)
12
{
13
14
Scanner sc
=
new
Scanner(System.in);
15
int
t
=
sc.nextInt();
16
for
(
int
ii
=
0
; ii
<
t; ii
++
)
17
{
18
for
(
int
j
=
0
; j
<
map1.length; j
++
)
19
{
20
Arrays.fill(map1[j],
0
);
21
Arrays.fill(map2[j],
0
);
22
}
23
Arrays.fill(ctnd1,
new
CountNode(
0
));
24
Arrays.fill(ctnd2,
new
CountNode(
0
));
25
26
col
=
sc.nextInt();
27
row
=
sc.nextInt();
28
int
n
=
sc.nextInt();
29
int
thiscol, thisrow;
30
//
31
//
System.out.println("col=" + col + " row=" + row + " n=" + n);
32
//
33
for
(
int
k
=
0
; k
<
n; k
++
)
//
read map1[][]
34
{
35
thiscol
=
sc.nextInt();
36
thisrow
=
sc.nextInt();
37
38
map1[thisrow][thiscol]
=
1
;
39
}
40
for
(
int
k
=
0
; k
<
n; k
++
)
//
read map2[][]
41
{
42
thiscol
=
sc.nextInt();
43
thisrow
=
sc.nextInt();
44
45
map2[thisrow][thiscol]
=
1
;
46
}
47
//
48
/**/
/*
System.out.println("map1[][]");
49
for(int i = 0; i < row; i++)
50
{
51
for(int j = 0; j < col; j++)
52
System.out.print(map1[i][j]);
53
System.out.println();
54
}
55
System.out.println("map2[][]");
56
for(int i = 0; i < row; i++)
57
{
58
for(int j = 0; j < col; j++)
59
System.out.print(map2[i][j]);
60
System.out.println();
61
}
*/
62
//
63
getAllCounts();
64
Arrays.sort(ctnd1);
65
Arrays.sort(ctnd2);
66
boolean
flag
=
true
;
67
for
(
int
i
=
0
; i
<
ctnd1.length; i
++
)
68
{
69
if
(ctnd1[i].getCount()
!=
ctnd2[i].getCount())
{
70
flag
=
false
;
71
System.out.println(
"
NO
"
);
72
break
;
73
}
74
}
75
if
(flag)
76
System.out.println(
"
YES
"
);
77
}
78
79
}
80
private
static
void
getAllCounts()
81
{
82
int
p
=
0
;
83
for
(
int
i
=
0
; i
<
row; i
++
)
84
{
85
for
(
int
j
=
0
; j
<
col; j
++
)
86
{
87
if
(map1[i][j]
==
1
)
88
ctnd1[p
++
]
=
new
CountNode(getThisMap1Counts(i, j));
89
if
(map2[i][j]
==
1
)
90
ctnd2[p
++
]
=
new
CountNode(getThisMap2Counts(i, j));
91
}
92
}
93
}
94
private
static
int
getThisMap1Counts(
int
r,
int
c)
//
map1[][]的連通度
95
{
96
int
count
=
0
;
97
for
(
int
i
=
r
-
1
; i
>=
0
&&
map1[i][c]
==
1
; i
--
)
98
count
++
;
99
for
(
int
i
=
r
+
1
; i
<
row
&&
map1[i][c]
==
1
; i
++
)
100
count
++
;
101
for
(
int
i
=
c
-
1
; i
>=
0
&&
map1[r][i]
==
1
; i
--
)
102
count
++
;
103
for
(
int
i
=
c
+
1
; i
<
col
&&
map1[r][i]
==
1
; i
++
)
104
count
++
;
105
return
count
+
1
;
106
}
107
private
static
int
getThisMap2Counts(
int
r,
int
c)
//
map2[][]的連通度
108
{
109
int
count
=
0
;
110
for
(
int
i
=
r
-
1
; i
>=
0
&&
map2[i][c]
==
1
; i
--
)
111
count
++
;
112
for
(
int
i
=
r
+
1
; i
<
row
&&
map2[i][c]
==
1
; i
++
)
113
count
++
;
114
for
(
int
i
=
c
-
1
; i
>=
0
&&
map2[r][i]
==
1
; i
--
)
115
count
++
;
116
for
(
int
i
=
c
+
1
; i
<
col
&&
map2[r][i]
==
1
; i
++
)
117
count
++
;
118
return
count
+
1
;
119
}
120
121
122
}
123
class
CountNode
implements
Comparable
<
CountNode
>
124
{
125
private
int
count;
126
public
CountNode(
int
count)
127
{
128
this
.count
=
count;
129
}
130
public
int
getCount()
131
{
132
return
count;
133
}
134
public
int
compareTo(CountNode n2)
135
{
136
return
n2.count
-
this
.count;
137
}
138
}
139
posted on 2013-04-14 20:10
小鼠標
閱讀(517)
評論(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.?單調隊列(5507)
2.?Linux select()函數使用(4003)
3.?快速排序、線性時間選擇(3744)
4.?poj3468--絕對經典的線段樹題(3661)
5.?優先隊列--堆實現(3319)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
亚洲精品欧美极品
|
亚洲网址在线
|
久久综合伊人
|
美女黄色成人网
|
亚洲精品一二三
|
欧美mv日韩mv国产网站app
|
亚洲高清免费在线
|
av成人免费在线观看
|
国产有码一区二区
|
亚洲电影在线看
|
欧美日产一区二区三区在线观看
|
性欧美精品高清
|
亚洲国产激情
|
狠狠久久五月精品中文字幕
|
久久精品免费
|
亚洲国产欧美在线人成
|
新狼窝色av性久久久久久
|
久久国产免费
|
亚洲激情欧美
|
欧美亚洲免费
|
伊人男人综合视频网
|
久久激情视频久久
|
亚洲精品孕妇
|
久久久国产午夜精品
|
午夜一级久久
|
狠狠做深爱婷婷久久综合一区
|
久久国产福利
|
久久久久88色偷偷免费
|
原创国产精品91
|
亚洲经典在线
|
欧美色图麻豆
|
欧美一区观看
|
久久精品国产在热久久
|
91久久精品一区
|
亚洲精品你懂的
|
国产精品三级久久久久久电影
|
久久久99免费视频
|
女女同性精品视频
|
亚洲影院色无极综合
|
欧美亚洲综合网
|
亚洲免费观看高清完整版在线观看
|
亚洲免费电影在线观看
|
国产亚洲精品综合一区91
|
欧美电影在线
|
国产精品久久一卡二卡
|
另类图片国产
|
国产精品二区三区四区
|
久久综合九色九九
|
欧美日韩一区三区四区
|
久热精品视频在线
|
欧美色图天堂网
|
免费人成网站在线观看欧美高清
|
欧美日韩高清免费
|
老鸭窝亚洲一区二区三区
|
亚洲欧美日韩国产一区
|
一区二区高清在线
|
国产在线视频欧美
|
91久久久久久久久
|
激情婷婷久久
|
一区二区三区免费观看
|
在线观看欧美
|
亚洲欧美999
|
在线亚洲成人
|
六月婷婷一区
|
久久精品成人
|
欧美午夜激情在线
|
亚洲高清视频的网址
|
国产一区二区日韩精品
|
一区二区三区欧美在线
|
亚洲人永久免费
|
久久国内精品视频
|
午夜精品久久久久久久久久久久久
|
蜜臀av国产精品久久久久
|
久久久精品一区二区三区
|
欧美午夜免费影院
|
亚洲高清不卡在线观看
|
伊人狠狠色j香婷婷综合
|
亚洲欧美日韩在线综合
|
亚洲免费在线看
|
欧美日韩高清一区
|
亚洲国产精品精华液网站
|
在线观看视频一区二区
|
欧美一区二区在线视频
|
欧美一区二区三区在
|
国产精品jizz在线观看美国
|
亚洲三级毛片
|
日韩五码在线
|
欧美极品在线观看
|
亚洲人久久久
|
一区二区精品在线
|
欧美精品情趣视频
|
亚洲精品中文字幕在线
|
一本到高清视频免费精品
|
欧美乱大交xxxxx
|
亚洲激情啪啪
|
一本在线高清不卡dvd
|
欧美另类亚洲
|
一本色道精品久久一区二区三区
|
亚洲一品av免费观看
|
在线亚洲激情
|
国产精品欧美久久久久无广告
|
亚洲视频一区二区
|
欧美一级理论片
|
国产偷自视频区视频一区二区
|
午夜精品福利在线观看
|
久久久91精品国产
|
亚洲国产成人精品女人久久久
|
男女av一区三区二区色多
|
亚洲欧洲一区二区在线观看
|
国产精品99久久99久久久二8
|
欧美视频一区二区在线观看
|
亚洲一区精品视频
|
久久精品国产精品亚洲综合
|
精品动漫av
|
欧美精品videossex性护士
|
日韩网站在线看片你懂的
|
午夜精品久久久久久99热软件
|
国产一区二区三区奇米久涩
|
另类人畜视频在线
|
久久精品夜色噜噜亚洲aⅴ
|
欧美成人高清
|
一本色道88久久加勒比精品
|
国产精品美女一区二区
|
久久国产综合精品
|
亚洲精品中文在线
|
久久伊人精品天天
|
亚洲午夜久久久久久久久电影院
|
国产一区二区精品
|
欧美日韩国产一区二区
|
欧美在线一级视频
|
日韩一级免费观看
|
老色鬼久久亚洲一区二区
|
99re6热在线精品视频播放速度
|
国产精品永久免费视频
|
欧美成人综合
|
欧美一区久久
|
亚洲免费av网站
|
久久影视精品
|
一区二区三区四区精品
|
精久久久久久
|
欧美日韩国产色综合一二三四
|
久久久久久久成人
|
一本久久综合亚洲鲁鲁五月天
|
麻豆成人综合网
|
午夜精品电影
|
亚洲人www
|
国产一区亚洲
|
国产精品视频第一区
|
欧美日韩国产首页在线观看
|
老司机午夜精品视频
|
久久久999精品
|
亚洲欧美电影院
|
日韩一级在线
|
亚洲激情在线
|
免费日韩精品中文字幕视频在线
|
一本色道久久综合亚洲91
|
女同一区二区
|
欧美一区二区三区视频免费
|
亚洲日本成人在线观看
|
影音先锋久久
|
狠狠色狠狠色综合日日五
|
国产精品激情偷乱一区二区∴
|
欧美~级网站不卡
|
久久精品国产清高在天天线
|
亚洲自拍16p
|
亚洲一区999
|
亚洲乱码国产乱码精品精天堂
|
欧美成人免费网
|
免费亚洲电影
|
免播放器亚洲一区
|
久久综合狠狠
|
久久精品理论片
|
欧美专区在线观看
|
亚洲香蕉网站
|
在线视频中文亚洲
|
在线视频欧美日韩精品
|
亚洲一区二区欧美日韩
|
亚洲日韩第九十九页
|
亚洲国产精品va在线看黑人
|
国外精品视频
|
亚洲国产91色在线
|
亚洲日本国产
|
一区二区国产日产
|
一本久久知道综合久久
|
99国产一区
|
日韩午夜剧场
|
亚洲一区二区三区涩
|
亚洲欧洲av一区二区三区久久
|
欧美一级电影久久
|
久久国产精品电影
|
免费观看日韩av
|
欧美经典一区二区
|
国产精品推荐精品
|
激情综合在线
|
日韩一区二区电影网
|
亚洲一区二区三区激情
|
国产精品久久国产三级国电话系列
|
欧美日韩另类字幕中文
|
亚洲第一精品电影
|
亚洲一区二区三区影院
|