HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯(lián)系
管理
ZOJ1002Fire Net
深度加回溯,類似于八皇后問題。
#include
<
stdio.h
>
#include
<
string
.h
>
#include
<
stdlib.h
>
char
mp[
6
][
6
];
//
map
int
len;
//
map length
int
mb;
//
bigesst
int
mbt;
//
now road length
int
CP(
int
x,
int
y)
//
canput
{
int
i;
i
=
y
-
1
;
while
(i
>=
0
&&
mp[x][i]
!=
'
X
'
)
{
if
(mp[x][i]
==
'
O
'
)
return
0
;
i
--
;
}
i
=
y
+
1
;
while
(i
<
len
&&
mp[x][i]
!=
'
X
'
)
{
if
(mp[x][i]
==
'
O
'
)
return
0
;
i
++
;
}
i
=
x
-
1
;
while
(i
>=
0
&&
mp[i][y]
!=
'
X
'
)
{
if
(mp[i][y]
==
'
O
'
)
return
0
;
i
--
;
}
i
=
x
+
1
;
while
(i
<
len
&&
mp[i][y]
!=
'
X
'
)
{
if
(mp[i][y]
==
'
O
'
)
return
0
;
i
++
;
}
return
1
;
}
void
DFS(
int
n)
{
int
i, j;
int
x, y;
if
(n
==
len
*
len)
{
if
(mb
<
mbt)
mb
=
mbt;
return
;
}
x
=
n
/
len;
y
=
n
%
len;
if
(mp[x][y]
==
'
.
'
&&
CP(x, y))
{
mp[x][y]
=
'
O
'
;
mbt
++
;
DFS(n
+
1
);
mbt
--
;
mp[x][y]
=
'
.
'
;
DFS(n
+
1
);
}
else
DFS(n
+
1
);
}
int
main()
{
int
i, j;
scanf(
"
%d
"
,
&
len);
getchar();
while
(len
!=
0
)
{
for
(i
=
0
; i
<
len; i
++
)
//
read map
gets(mp[i]);
mbt
=
mb
=
0
;
DFS(
0
);
printf(
"
%d\n
"
, mb);
scanf(
"
%d
"
,
&
len);
getchar();
}
}
這道題跟之前走迷宮的題略有不同,走迷宮時(shí)起始點(diǎn)確定,當(dāng)前點(diǎn)可走的方向確定。而這道題結(jié)束條件是判斷過的格數(shù)超過總格數(shù)。
即使是合法的點(diǎn)也可以選擇不放炮臺(tái)。
posted on 2012-03-08 23:34
小鼠標(biāo)
閱讀(215)
評(píng)論(0)
編輯
收藏
引用
只有注冊(cè)用戶
登錄
后才能發(fā)表評(píng)論。
【推薦】100%開源!大型工業(yè)跨平臺(tái)軟件C++源碼提供,建模,組態(tài)!
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標(biāo) Powered by:
博客園
模板提供:
滬江博客
<
2012年8月
>
日
一
二
三
四
五
六
29
30
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
31
1
2
3
4
5
6
7
8
常用鏈接
我的隨筆
我的評(píng)論
我參與的隨筆
隨筆分類
(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
最新評(píng)論
1.?re: 線段樹
是這個(gè)樣子的,所以在OJ有時(shí)候“卡住”了也不要太灰心,沒準(zhǔn)真的不是自己的原因呢。
加油,祝你好運(yùn)啦!
--小鼠標(biāo)
2.?re: 線段樹
對(duì)于編程競(jìng)賽來說,Java所需時(shí)間一般為C/C++的兩倍。合理的競(jìng)賽給Java的時(shí)間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網(wǎng)絡(luò)流
過來看看你。
--achiberx
4.?re: (轉(zhuǎn))ubuntu11.10無法啟動(dòng)無線網(wǎng)絡(luò)的解決方法
膜拜大神。。查了一個(gè)下午資料終于在這里解決了問題。。神牛說的區(qū)域賽難道是ACM區(qū)域賽。。?
--Hang
5.?re: 快速排序、線性時(shí)間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區(qū)基準(zhǔn)在數(shù)組中重復(fù)的情況,書上的方法遇到這種輸入會(huì)堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調(diào)隊(duì)列(5497)
2.?Linux select()函數(shù)使用(3990)
3.?快速排序、線性時(shí)間選擇(3719)
4.?poj3468--絕對(duì)經(jīng)典的線段樹題(3642)
5.?優(yōu)先隊(duì)列--堆實(shí)現(xiàn)(3309)
久久久噜噜噜久久熟女AA片
|
99精品国产在热久久无毒不卡
|
久久久精品人妻无码专区不卡
|
99久久国产热无码精品免费久久久久
|
99精品国产在热久久无毒不卡
|
国产亚洲精午夜久久久久久
|
中文字幕热久久久久久久
|
久久精品无码一区二区无码
|
精品久久一区二区
|
亚洲欧美国产日韩综合久久
|
午夜不卡久久精品无码免费
|
国产成人久久精品麻豆一区
|
久久久久亚洲AV无码网站
|
国产精品成人99久久久久
|
新狼窝色AV性久久久久久
|
免费国产99久久久香蕉
|
久久久久久九九99精品
|
国内精品伊人久久久久妇
|
国产亚洲成人久久
|
久久亚洲精品视频
|
国内精品久久久久久久97牛牛
|
久久久无码精品亚洲日韩软件
|
久久精品www人人爽人人
|
亚洲国产天堂久久综合
|
国产成人香蕉久久久久
|
97久久精品无码一区二区
|
亚洲国产精品无码久久久蜜芽
|
久久亚洲av无码精品浪潮
|
93精91精品国产综合久久香蕉
|
2022年国产精品久久久久
|
日韩av无码久久精品免费
|
久久AV高潮AV无码AV
|
日韩欧美亚洲国产精品字幕久久久
|
久久综合狠狠色综合伊人
|
国产精品99久久99久久久
|
成人妇女免费播放久久久
|
日韩av无码久久精品免费
|
精品熟女少妇a∨免费久久
|
久久精品亚洲一区二区三区浴池
|
亚洲AV无码一区东京热久久
|
久久人人爽人人爽人人片AV东京热
|