HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
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();
}
}
這道題跟之前走迷宮的題略有不同,走迷宮時起始點確定,當前點可走的方向確定。而這道題結束條件是判斷過的格數超過總格數。
即使是合法的點也可以選擇不放炮臺。
posted on 2012-03-08 23:34
小鼠標
閱讀(212)
評論(0)
編輯
收藏
引用
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標 Powered by:
博客園
模板提供:
滬江博客
<
2012年3月
>
日
一
二
三
四
五
六
26
27
28
29
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
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(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.?單調隊列(5493)
2.?Linux select()函數使用(3982)
3.?快速排序、線性時間選擇(3695)
4.?poj3468--絕對經典的線段樹題(3640)
5.?優先隊列--堆實現(3305)
亚洲欧美另类日本久久国产真实乱对白
|
97久久婷婷五月综合色d啪蜜芽
|
国产—久久香蕉国产线看观看
|
久久这里只有精品久久
|
国内精品久久久久国产盗摄
|
久久婷婷人人澡人人
|
一本一本久久a久久综合精品蜜桃
|
人妻无码αv中文字幕久久
|
99久久久国产精品免费无卡顿
|
曰曰摸天天摸人人看久久久
|
久久伊人精品一区二区三区
|
久久99热狠狠色精品一区
|
人妻中文久久久久
|
国产精品熟女福利久久AV
|
伊人久久大香线蕉av一区
|
久久精品无码一区二区三区日韩
|
99久久国产免费福利
|
日韩精品久久无码中文字幕
|
久久无码一区二区三区少妇
|
青青草原综合久久大伊人
|
国内精品久久久久久久久
|
99久久综合狠狠综合久久止
|
久久午夜免费视频
|
久久亚洲欧洲国产综合
|
国产免费久久精品99久久
|
99国产欧美精品久久久蜜芽
|
亚洲乱码精品久久久久..
|
91久久香蕉国产熟女线看
|
精品久久久久久亚洲精品
|
日韩av无码久久精品免费
|
区久久AAA片69亚洲
|
偷偷做久久久久网站
|
久久综合偷偷噜噜噜色
|
日韩久久无码免费毛片软件
|
国产精品丝袜久久久久久不卡
|
久久久久亚洲Av无码专
|
青青草原精品99久久精品66
|
亚洲精品乱码久久久久66
|
久久久久亚洲精品天堂
|
久久最近最新中文字幕大全
|
亚洲国产精品久久久久
|