题目描述
在命令行输入如下命令: xcopy /s c:\ d:\, 各个参数如下:
参数1:命令字xcopy
参数2:字符串/s
参数3:字符串c:\
参数4: 字符串d:\
请编写一个参数解析程序,实现将命令行各个参数解析出来。
解析规则:
1.参数分隔符为空格
2.对于用“”包含起来的参数,如果中间有空格,不能解析为多个参数。
比如在命令行输入xcopy /s “C:\program files” “d:\”时,参数仍然是4个,
第3个参数应该是字符串C:\program files,而不是C:\program,注意输出参数时,需要将“”去掉,引号不存在嵌套情况。
3.参数不定长
4.输入由用例保证,不会出现不符合要求的输入
输入描述
输入一行字符串,可以有空格
输出描述
输出参数个数,分解后的参数,每个参数都独占一行
输入例子
xcopy /s c:\\\ d:\\\
输出例子
4
xcopy
/s
c:\\\
d:\\\
算法实现
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* Author: 王俊超
* Date: 2015-12-25 08:31
* Declaration: All Rights Reserved !!!
*/
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
String input = scanner.nextLine();
System.out.println(argAnalysis(input));
}
scanner.close();
}
/**
* 分析参数,【还有另外一种方法,就是直接利用数组来处理,可减少时间复杂度和空间复杂度,处理起来会麻烦一些】
* @param s
* @return
*/
private static String argAnalysis(String s) {
List<String> list = new ArrayList<>();
int prev = 0;
for (int i = 0; i < s.length(); ) {
if (s.charAt(i) == '"') {
list.add(s.substring(prev, i));
for (int j = i + 1; j < s.length(); j++) {
if (s.charAt(j) == '"') {
list.add(s.substring(i, j + 1));
i = j + 1;
prev = i;
}
}
} else {
i++;
}
}
if (prev < s.length()) {
list.add(s.substring(prev, s.length()));
}
int result = 0;
StringBuilder builder = new StringBuilder();
for (String t : list) {
if (!t.startsWith("\"")) {
String[] sts = t.split("\\s+");
result += sts.length;
for (String st : sts) {
builder.append(st).append('\n');
}
} else {
result++;
builder.append(t).append('\n');
}
}
return result + "\n" + builder.substring(0, builder.length() - 1);
}
}