题解 | #参数解析#

参数解析

https://www.nowcoder.com/practice/668603dc307e4ef4bb07bcd0615ea677

//本大神的杰作
//双引号设置一个标志是否出现过, 存储左右双引号位置, 对双引号的内容进行剪切
//记录左空格位置, 再遇到空格时进行剪切
//循环到末尾没有空格没有双引号也要根据空格位置进行剪切
//但是如果双引号周围有空格, 可能会重复剪切, 所以双引号剪切完了, 左空格位置右移, 如果下一个是空格就不用处理了
/*
描述
在命令行输入如下命令:

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
≤
s
≤
1000
 
1≤s≤1000 
进阶:时间复杂度:
O
(
n
)
 
O(n) ,空间复杂度:
O
(
n
)
 
O(n) 
输入描述:
输入一行字符串,可以有空格

输出描述:
输出参数个数,分解后的参数,每个参数都独占一行
*/
import java.util.ArrayList;
import java.util.Scanner;

public class Main
{
    public static void main(String[] args)
    {
        Scanner sc = new Scanner(System.in);
        String str = sc.nextLine();
        ArrayList<String> list = new ArrayList<>();
        int slow = 0;
        int exitYinhao = 0;
        int lYinhao=0, rYinhao=0, lSpace=0;

        for (int i = 0; i < str.length(); i++)
        {
            char ch = str.charAt(i);
            if( ch=='"' && exitYinhao == 0)
            {
                lYinhao = i;
                exitYinhao = 1;
                continue;
            }
            else if( ch=='"' && exitYinhao == 1 )
            {
                rYinhao = i;
                exitYinhao = 0;
                list.add( str.substring(lYinhao+1,rYinhao) );
                lSpace = i+1;
            }
            else if( ch == ' ' && exitYinhao == 0)
            {
                if(i==lSpace)
                {
                    lSpace = i+1;
                    continue;
                }
                list.add( str.substring(lSpace,i) );
                lSpace = i+1;
            }
            else if ( i==str.length()-1 )
            {
                list.add( str.substring(lSpace,i+1) );
            }
        }
        System.out.println(list.size());
        for(String s:list)
        {
            System.out.println(s);
        }
    }
}

华为机试题解 文章被收录于专栏

华为机试题解

全部评论

相关推荐

面试官全程关摄像头1.自我介绍一下2.React和Vue哪个更熟悉一点3.你在之前那段实习经历中有没有什么技术性的突破(我只是实习了44天工作28天,我把我能说的都说了)4.你封装的哪个表单组件支不支持动态传值5.自己在实习阶段Vue3项目封装过hook吗6.hook有什么作用7.Vue2和Vue3的响应式区别(我说一个是proxy是拦截所有的底层操作,Object.defineProperty本身就是一个底层操作,有些东西拦截不了,比如数组的一些操作还有等等,面试官就说实在要拦截能不能拦截????我心想肯定不行呀,他的底层机制就不允许吧)8.pinia和vuex的区别(这个回答不出来是我太久没用了)9.pinia和zustand的区别,怎么选(直接给我干懵了)(我说react能用pinia吗&nbsp;&nbsp;他说要用的话也可以)10.渲染一万条数据,怎么解决页面卡顿问题(我说分页、监听滚轮动态加载,纯数据展示好像还可以用canvas画)(估计是没说虚拟表单,感觉不满意)11.type和interface的区别12.ts的泛型有哪些作用(我就说了一个结构相同但是类型不同的时候可以用,比如请求响应的接口,每次的data不同,这里能用一个泛型,他问我还有什么)13.你项目用的是React,如果让你再写一遍你会选择什么14.pnpm、npm、yarn的区别15.dependencies和devdependencies的区别总而言之太久没面试了,上一段实习的面试js问了很多。结果这次js一点没问,网络方面也没考,表现得很一般,但是知道自己的问题了&nbsp;&nbsp;好好准备,等待明天的影石360和周四的腾讯了&nbsp;&nbsp;加油!!!
解zj:大三的第一段面试居然是这样的结局
查看15道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务