一次比赛里的题,模拟DOS里的dir、deltree命令,直接贴代码了,这种题目就感觉到java的String类强大了,话说spilt方法似乎有点小bug。。用正则表达式表示多个prtten都不可以,不解。。贴代码
1
import java.io.*;
2
import java.util.*;
3
class node
4data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
5
HashMap<String,node> dir=new HashMap<String,node>();
6
HashMap<String,Integer> file=new HashMap<String,Integer>();
7
node per=null;
8
};
9data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
public class Main
{
10data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
11data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
/** *//**
12
* @param args
13
*/
14
static node head;
15
static int total;
16
static void del(node p)
17data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
18
Collection<node> dir=p.dir.values();
19
Collection<Integer> tmp=p.file.values();
20
for(Integer pos:tmp)
21
total+=pos;
22
for(node pos:dir)
23
del(pos);
24
p.dir.clear();
25
p.file.clear();
26
27
}
28data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
public static void main(String[] args) throws IOException
{
29
BufferedReader in=new BufferedReader(new InputStreamReader(System.in));
30
while(true)
31data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
32
head=new node();
33
String str=in.readLine();
34
if(str.equals(">exit")) break;
35
node p=head;
36
total=0;
37
while(true)
38data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
39
if(str.length()==0) break;
40
str=str.substring(1);
41
if(str.startsWith("cd"))
42data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
43
str=str.substring(3);
44
if(str.charAt(0)=='\\')
45data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
46
while(p!=head) p=p.per;
47
str=str.substring(1);
48
}
49
else if(str.charAt(0)=='.')
50data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
51
p=p.per;
52
str=str.substring(2);
53
}
54
if(str.length()!=0)
55data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
56
while(str.indexOf('\\')!=-1)
57data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
58
String t=str.substring(0,str.indexOf('\\'));
59
str=str.substring(str.indexOf('\\')+1);
60
if(p.dir.containsKey(t))
61
p=p.dir.get(t);
62
else
63data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
64
node tmp=new node();
65
tmp.per=p;
66
p.dir.put(t, tmp);
67
p=tmp;
68
}
69
}
70
if(p.dir.containsKey(str))
71
p=p.dir.get(str);
72
else
73data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
74
node tmp=new node();
75
tmp.per=p;
76
p.dir.put(str, tmp);
77
p=tmp;
78
}
79
}
80
81
str=in.readLine();
82
}
83
else if(str.startsWith("dir"))
84data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
85
while(true)
86data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
87
str=in.readLine();
88
if(str.length()==0||str.charAt(0)=='>') break;
89
String sp[]=str.split(" ");
90
if(sp.length==2)
91data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
92
if(!p.file.containsKey(sp[0]))
93
p.file.put(sp[0], Integer.parseInt(sp[1]));
94
}
95
else
96data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
97
if(!p.dir.containsKey(sp[0]))
98data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
99
node tmp=new node();
100
tmp.per=p;
101
p.dir.put(sp[0], tmp);
102
}
103
}
104
}
105
}
106
else
107data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
108
str=str.substring(8);
109
if(str.charAt(0)=='\\')
110data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
111
while(p!=head) p=p.per;
112
str=str.substring(1);
113
}
114
while(str.indexOf('\\')!=-1)
115data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
116
String tmp=str.substring(0,str.indexOf('\\'));
117
str=str.substring(str.indexOf('\\')+1);
118
p=p.dir.get(tmp);
119
}
120
p=p.dir.get(str);
121
del(p);
122
str=in.readLine();
123
124
}
125
}
126
System.out.println(total);
127
}
128
}
129data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
130
}
131data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
132data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""