dreamingnest
╰⊙д⊙╯。oо○
BlogJava
首页
新随笔
联系
聚合
管理
posts - 21, comments - 10, trackbacks - 0
BFS和DFS两种方法获取指定目录下的所有目录和文件
程序比较简单,BFS使用队列,DFS使用递归。读者可以根据需要改变打印顺序,而且还可以试图求出指定目录下的某一扩展名的文件数量,添加一点正则表达式的语句。
import
java.io.File;
import
java.util.LinkedList;
import
java.util.Queue;
public
class
BFS_SearchFiles
{
public
static
void
main(String args[])
{
Queue
<
File
>
queue
=
new
LinkedList
<
File
>
();
queue.add(
new
File(
"
c:\\test
"
));
while
(
!
queue.isEmpty())
{
File currentFile
=
(File)queue.poll();
System.out.println(
"
路径
"
+
currentFile);
String[] s
=
currentFile.list();
for
(
int
i
=
0
;i
<
s.length;i
++
)
{
File d
=
new
File(currentFile.getAbsolutePath()
+
File.separator
+
s[i]);
if
(d.isFile())
System.out.println(
"
文件
"
+
d);
else
if
(d.isDirectory())
queue.add(d);
}
}
}
}
import
java.io.File;
public
class
DFS_SearchFiles
{
public
static
void
main(String args[])
{
DFS_SearchFiles.Search(
"
c:\\test
"
);
}
static
void
Search(String path)
{
File file
=
new
File(path);
if
(file.isDirectory())
{
System.out.println(
"
目录
"
+
file.getPath());
File[] files
=
file.listFiles();
for
(
int
i
=
0
;i
<
files.length;i
++
)
{
if
(files[i].isDirectory())
{
Search(files[i].getPath());
}
else
if
(files[i].isFile())
System.out.println(
"
文件
"
+
files[i]);
}
}
}
}
posted on 2008-05-19 16:34
dreamingnest
阅读(93)
评论(1)
编辑
收藏
所属分类:
算法程序总结
FeedBack:
#
re: BFS和DFS两种方法获取指定目录下的所有目录和文件
2008-07-16 19:23 |
fejay
学习了
回复
更多评论
新闻频道
新用户注册
刷新评论列表
标题
姓名
主页
验证码
*
内容(请不要发表任何与政治相关的内容)
Remember Me?
登录
使用高级评论
新用户注册
返回页首
恢复上次提交
[使用Ctrl+Enter键可以直接提交]
相关链接:
网站导航:
博客园
BlogJava
博客生活
IT博客网
C++博客
PHP博客
博客园社区
管理博客
教师博客
天文博客
汽车博客
足球博客
股票博客
电子博客
管理
相关文章:
BFS和DFS两种方法获取指定目录下的所有目录和文件
堆栈解(非递归)决迷宫问题
<
2008年5月
>
日
一
二
三
四
五
六
27
28
29
30
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
常用链接
我的随笔
我的文章
我的评论
我的参与
最新评论
留言簿
给我留言
查看公开留言
查看私人留言
随笔分类
(15)
应用程序(4)
我的生活我的歌(2)
算法程序总结(2)
链表和栈(结)(7)
随笔档案
(22)
2008年5月 (9)
2008年4月 (13)
外面的世界
懒散狂徒的专栏(天行健,君子以自强不息 地势坤,君子以厚德载物)
这里的朋友
保尔任(思想比知识更重要 成长比成功更重要)
搜索
最新评论
1. re: BFS和DFS两种方法获取指定目录下的所有目录和文件
学习了
--fejay
2. re: 关于蚂蚁问题(Ants)
实际过程可以这么进行抽象模拟:
序列中的元素带有方向,进行负值部分移动到负值区域,正值部分移动到正值区域时就不再发生碰撞,此时绝对值最小的值决定剩余爬行时间
--zdh
3. re: 关于蚂蚁问题(Ants)
这个问题看到实质就很简单,所有的蚂蚁都是相同的蚂蚁,因此可以看成所有的蚂蚁都可以穿过对面爬过来的蚂蚁就ok啦,最长时间就是两端的蚂蚁向另一端爬出去,最短的就是两端的四个蚂蚁向所在端爬出:)
--zdh
4. re: 最喜爱的两位钢琴家~Yanni & Maksim
偶的窄屏也可以。。
--小京同志
5. re: 我们-献给BlogJava
借用别人的几句。
蚯蚓
听到春天的气息
出来
....
没有涵义,不用乱猜了。。
--我们伟大的小京
阅读排行榜
1. 关于蚂蚁问题(Ants)(972)
2. ~·扫雷小游戏·~(637)
3. 通过排序总结java泛型数组列表(210)
4. 打开文件,将所有小写字母变为大写,并存入文件(96)
5. 计算指定路径下所有java文件的代码行数(95)
评论排行榜
1. 关于蚂蚁问题(Ants)(7)
2. 我们-献给BlogJava(1)
3. 最喜爱的两位钢琴家~Yanni & Maksim(1)
4. BFS和DFS两种方法获取指定目录下的所有目录和文件(1)
5. ACM中使用JAVA的介绍(0)