码迷,mamicode.com
首页 > 其他好文 > 详细

【华为OJ】【048-参数解析】

时间:2016-05-13 14:53:28      阅读:238      评论:0      收藏:0      [点我收藏+]

标签:

【华为OJ】【算法总篇章】


【华为OJ】【048-参数解析】

【工程下载】


题目描述

在命令行输入如下命令: 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);
//        Scanner scanner = new Scanner(Main.class.getClassLoader().getResourceAsStream("data.txt"));
        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<>();

        // 表示最后一个"出现的下一个位置,如果没有"就为0
        int prev = 0;
        for (int i = 0; i < s.length(); ) {
            // i开始的第一个双引号
            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++;
            }
        }

        // 【1】
//        // 表示没有"
//        if (prev == 0) {
//            list.add(s);
//        }
//        // 还有最后一个没有
//        else if (prev < s.length()) {
//            list.add(s.substring(prev, s.length()));
//        }

        // 【2】,【1】【2】实现同样的效果
        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);
    }
}

【华为OJ】【048-参数解析】

标签:

原文地址:http://blog.csdn.net/derrantcm/article/details/51380954

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!