今天在CSDN看到一个笔试题,觉得蛮有意思的,
题目如下:
从事先写好的Input.txt文件中读取数,
Input.txt 内容
A{13,2,1,20,30,50}
B{1,2,34,5,6}
C{2,3,12,23,14,11}
用户在键盘随意敲入...例如((A*B))+B-C,((C+B)*A)-B期中+,*,-,分别代表集合的并交差运算,控制台打印输出。
开始的时候打算用栈来计算的,
但想了想,不会搞,还是来个笨方法吧。
废话不多说,贴代码。
代码写的很烂,汗了!
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/** *//**
2
* 从事先写好的Input.txt文件中读取数,
3
* Input.txt 内容
4
* A{13,2,1,20,30,50}
5
* B{1,2,34,5,6}
6
* C{2,3,12,23,14,11}
7
* 用户在键盘随意敲入
例如((A*B))+B-C,((C+B)*A)-B期中+,*,-,分别代表集合的并交差运算,控制台打印输出。
8
*/
9
package com.lim.test;
10data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
11
import java.io.BufferedReader;
12
import java.io.FileInputStream;
13
import java.io.IOException;
14
import java.io.InputStreamReader;
15
import java.lang.reflect.InvocationTargetException;
16
import java.lang.reflect.Method;
17
import java.util.ArrayList;
18
import java.util.List;
19data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
20data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/** *//**
21
* @author bzwm
22
*
23
*/
24data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class EditorString
{
25
private Type a = null;
26data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
27
private Type b = null;
28data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
29
private Type c = null;
30data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
31
private Type t = null;
32data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
33data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
34
* 读入指定的文件
35
*
36
* @param path
37
*/
38data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void readFile(String path)
{
39
BufferedReader reader = null;
40data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
41
reader = new BufferedReader(new InputStreamReader(
42
new FileInputStream(path)));
43
String str = null;
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while ((str = reader.readLine()) != null)
{
45data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
46data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (str.substring(0, 1).equals("A"))
{
47
a = new Type(str);
48data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (str.substring(0, 1).equals("B"))
{
49
b = new Type(str);
50data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (str.substring(0, 1).equals("C"))
{
51
c = new Type(str);
52data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (str.substring(0, 1).equals("T"))
{
53
t = new Type(str);
54data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
55
System.out.println("no such type!");
56
return;
57
}
58
}
59data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
60
e.printStackTrace();
61
return;
62
}
63
}
64data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
65data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
66
* 处理并、交、差操作,显示结果
67
*
68
* @param rule
69
*/
70data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void displayResult(String rule)
{
71
int start = 0;
72
int end = 0;
73data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (rule.length() > 2)
{
74data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (rule.contains("("))
{
75
start = rule.lastIndexOf("(");
76
end = start + 4;
77
rule = execute(start, end, rule);
78data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
79
start = 0;
80
end = start + 2;
81
rule = executeNormal(start, end, rule);
82
}
83
}
84
List result = t.getArray();
85
for (int i = 0; i < result.size(); i++)
86
System.out.println(result.get(i));
87
}
88data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
89data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
90
* 处理并、交、差操作
91
*
92
* @param start
93
* @param end
94
* @param rule
95
* @return rule
96
*/
97data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private String execute(int start, int end, String rule)
{
98
int size = rule.length();
99
Type obj = typeFactory(rule.substring(start + 1, start + 2));
100
String ope = rule.substring(start + 2, start + 3);
101
Type arg = typeFactory(rule.substring(end - 1, end));
102data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
103
t = execute(obj, arg, ope);
104data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
105
e.printStackTrace();
106
}
107
return rule.substring(0, start) + "T" + rule.substring(end + 1, size);
108
}
109data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
110
* 当用户输入的rule没有括号的情况:处理并、交、差操作
111
* @param start
112
* @param end
113
* @param rule
114
* @return rule
115
*/
116data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private String executeNormal(int start, int end, String rule)
{
117
int size = rule.length();
118
Type obj = typeFactory(rule.substring(start, start + 1));
119
String ope = rule.substring(start + 1, start + 2);
120
Type arg = typeFactory(rule.substring(end, end + 1));
121data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
122
t = execute(obj, arg, ope);
123data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
124
e.printStackTrace();
125
}
126
return rule.substring(0, start) + "T" + rule.substring(end + 1, size);
127
}
128data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
129data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
130
* 根据ope的不同,调用不同的方法
131
*
132
* @param obj
133
* @param arg
134
* @param ope
135
* @return
136
* @throws SecurityException
137
* @throws NoSuchMethodException
138
* @throws IllegalArgumentException
139
* @throws IllegalAccessException
140
* @throws InvocationTargetException
141
*/
142
private Type execute(Type obj, Type arg, String ope)
143
throws SecurityException, NoSuchMethodException,
144
IllegalArgumentException, IllegalAccessException,
145data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
InvocationTargetException
{
146
Class c = obj.getClass();
147
Class[] args = new Class[1];
148
args[0] = arg.getClass();
149
Method m = null;
150data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (ope.equals("+"))
{
151
m = c.getMethod("bing", args);
152data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (ope.equals("*"))
{
153
m = c.getMethod("jiao", args);
154data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (ope.equals("-"))
{
155
m = c.getMethod("cha", args);
156data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
157
System.out.println("NoSuchMethod");
158
return null;
159
}
160data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
return (Type) m.invoke(obj, new Object[]
{ arg });
161
}
162data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
163data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
164
* 读入用户输入的匹配规则 如:((C+B)*A)-B
165
*
166
* @return
167
*/
168data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static String readInput()
{
169
String ret = null;
170
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
171data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
172
ret = br.readLine();
173data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (IOException e)
{
174
e.printStackTrace();
175
return null;
176
}
177
return ret;
178
}
179data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
180data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
181
* 构造工厂
182
*
183
* @param type
184
* @return
185
*/
186data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private Type typeFactory(String type)
{
187data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (type.equals("A"))
{
188
return new Type(a.getArray());
189data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (type.equals("B"))
{
190
return new Type(b.getArray());
191data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (type.equals("C"))
{
192
return new Type(c.getArray());
193data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (type.equals("T"))
{
194
return new Type(t.getArray());
195data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
196
return null;
197
}
198
}
199data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
200data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
201
* 把如{13,2,1,20,30,50}的集合抽象成一个类,提供并、交、差操作
202
*
203
* @author bzwm
204
*
205
*/
206data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
class Type
{
207
private List array = new ArrayList();
208data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
209data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Type(String srt)
{
210
this.array = createList(srt);
211
}
212data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
213data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Type(List list)
{
214
this.array.addAll(list);
215
}
216data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
217data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public List getArray()
{
218
return this.array;
219
}
220data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
221data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
222
* 并操作
223
*
224
* @param arg
225
* @return
226
*/
227data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Type bing(Type arg)
{
228
// 是否加入到集合中的标志
229
boolean add = true;
230
// 取出传入的Type对象的List
231
List list = arg.getArray();
232
// 遍历传入的Type对象的List
233data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < list.size(); i++)
{
234
add = true;
235
// 与array里的值一一进行比较,如果全都不等,则加入到原array中,否则不加入
236data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int j = 0; j < array.size(); j++)
{
237
if (((Integer) list.get(i)).intValue() == ((Integer) array
238data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
.get(j)).intValue())
{
239
add = false;
240
}
241
}
242data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (add)
{
243
array.add(list.get(i));
244
}
245
}
246
// 返回新的Type对象
247
return new Type(array);
248
}
249data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
250data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
251
* 交操作
252
*
253
* @param arg
254
* @return
255
*/
256data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Type jiao(Type arg)
{
257
// 是否加入到集合中的标志
258
boolean add = false;
259
// 存放交集数据的List
260
List ret = new ArrayList();
261
// 取出传入的Type对象的List
262
List list = arg.getArray();
263
// 遍历传入的Type对象的List
264data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < list.size(); i++)
{
265
add = false;
266
// 与array里的值一一进行比较,如果有相等的,则加入到ret中,否则不加入
267data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int j = 0; j < array.size(); j++)
{
268
if (((Integer) list.get(i)).intValue() == ((Integer) array
269data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
.get(j)).intValue())
{
270
add = true;
271
}
272
}
273data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (add)
{
274
ret.add(list.get(i));
275
}
276
}
277
// 返回新的Type对象
278
return new Type(ret);
279
}
280data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
281data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
282
* 差操作
283
*
284
* @param arg
285
* @return
286
*/
287data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Type cha(Type arg)
{
288
// 是否加入到集合中的标志
289
boolean add = true;
290
// 存放交集数据的List
291
List list = arg.getArray();
292
// 遍历传入的Type对象的List
293data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < list.size(); i++)
{
294
add = true;
295
// 与array里的值一一进行比较,如果有相等的,则从原array中将其删除,如果全都不等,则加入到原array中
296data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int j = 0; j < array.size(); j++)
{
297
if (((Integer) list.get(i)).intValue() == ((Integer) array
298data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
.get(j)).intValue())
{
299
add = false;
300
// 删除相等的数据
301
array.remove(j);
302
}
303
}
304data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (add)
{
305
array.add(list.get(i));
306
}
307
}
308
// 返回新的Type对象
309
return new Type(array);
310
}
311data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
312data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
313
* 解析字符串,将数字加入到List中
314
*
315
* @param str
316
* @return
317
*/
318data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private List createList(String str)
{
319
// 将字符串解析成字符串数组A{13,2,1,20,30,50}-->new String[]{13,2,1,20,30,50}
320
String s[] = str.replaceAll(str.substring(0, 1), "").replace("{",
321
"").replace("}", "").split(",");
322
List list = new ArrayList();
323data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < s.length; i++)
{
324
list.add(new Integer(s[i]));
325
}
326
return list;
327
}
328
}
329data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
330data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
331
* 测试程序
332
* @param args
333
*/
334data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String args[])
{
335
EditorString es = new EditorString();
336
es.readFile("input.txt");
337
es.displayResult(readInput());//((C+B)*A)-B
338
}
339
}
340data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
341data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
----2008年11月25日