题解 | #参数解析#

参数解析

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);
        }
    }
}

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

华为机试题解

全部评论

相关推荐

03-21 10:53
复旦大学 Java
大家好,我是@程序员花海,眼下&nbsp;26&nbsp;届春招、27&nbsp;届暑期实习全面开启,后端卷到没边,AI&nbsp;Agent的岗位占主导,很多牛友在我的评论区留言,想让我出一份Agent学习路线。我特意去看了下,打开淘天的招聘页面,以校招为例,一眼望去全是AI相关的岗位,只能说之后绝大多数岗位都会快速推进AI的落地和实践。之前写过&nbsp;Java&nbsp;后端&nbsp;3&nbsp;个月抢救路线https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users,也收到了牛友们的强烈好评,这次专门给后端转&nbsp;Agent做一套最少必要知识路线——&nbsp;不堆概念、不啃论文,只学面试必问、项目...
在职牛马didi:这篇路线整理得很系统,把后端知识映射到Agent体系这个思路特别实用。我自己也是从Java转做AI的,感触很深:工程底子扎实的人转Agent确实有优势,RAG和工具编排这些核心能力本质上都是后端逻辑的延伸。我们团队在做天猫的AI应用落地,方向跟你这篇路线里的企业级RAG和Agent系统很接近。暑期实习还在招AI应用研发工程师,JD可以参考看看跟你背景是否匹配:https://www.nowcoder.com/jobs/detail/440929?jobId=440929
软件开发投递记录
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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