0
点赞
收藏
分享

微信扫一扫

#yyds干货盘点# 解决华为机试:参数解析

1.简述:

描述

在命令行输入如下命令:

xcopy /s c:\\ d:\\e,

各个参数如下:

参数1:命令字xcopy

参数2:字符串/s

参数3:字符串c:\\

参数4: 字符串d:\\e

请编写一个参数解析程序,实现将命令行各个参数解析出来。

解析规则:

1.参数分隔符为空格

2.对于用""包含起来的参数,如果中间有空格,不能解析为多个参数。比如在命令行输入xcopy /s "C:\\program files" "d:\"时,参数仍然是4个,第3个参数应该是字符串C:\\program files,而不是C:\\program,注意输出参数时,需要将""去掉,引号不存在嵌套情况。

3.参数不定长

4.输入由用例保证,不会出现不符合要求的输入数据范围:字符串长度:1\le s\le 1000\1≤s≤1000 进阶:时间复杂度:O(n)\O(n) ,空间复杂度:O(n)\O(n) 

输入描述:

输入一行字符串,可以有空格

输出描述:

输出参数个数,分解后的参数,每个参数都独占一行

示例1

输入:

xcopy /s c:\\ d:\\e

复制输出:

4
xcopy
/s
c:\\
d:\\e

2.代码实现:

import java.util.*;
public class Main {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
String s = sc.nextLine();
StringBuilder sb = new StringBuilder();
ArrayList<String> list = new ArrayList();
boolean flag = false;
for(int i=0;i<s.length();i++){
char c = s.charAt(i);
if(c=='"'){
//遇到第一个引号 flag为true,第二个引号 flag为false
flag = flag?false:true;
continue;//继续遍历下一个字符
}
//如果c是空格 ,且flag为false时,即没有引号 或已经是第二个引号结束
if(c==' ' && !flag){
list.add(sb.toString());//往集合中添加当前拼接到的字符串
sb = new StringBuilder();//置空 重新遍历下一个字符
}else{
//即 不是引号 也不是第二种逻辑
sb.append(c);
}
}
//最后遍历结束 没有空格或引号,需要再加上sb 打印出数组的长度,即几个命令
list.add(sb.toString());
System.out.println(list.size());
//打印出命令
for(String s1 : list){
System.out.println(s1);
}
}
}
}


举报

相关推荐

0 条评论