热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

程序员求职题目

问题

问题



  分析一个字符串,分析出字符串中的label情况,被"[]" 包围的字符串就是一个label,一个"[]"中可能包含多个label,以"," 或者 " "(空格)分隔,
如果label是用引号包含的则忽略其中的空格。


例子说明
lable
是一个字符串,下面的例子中简单起见用了abc等简单的字符,不要误解成就是一个字母
例子中的somthing就是任意的可包含回车,换行等字符的字符串。


例子1
[a]something
其中 有一个label:
a



例子2
[a][b]something
这个字符串有个两个label:
a
b



例子3
[a,b]something
这个字符串有个两个label:
a
b


例子4
[a,b][c]something
这个字符串有个三个label:
a
b
c


例子5
[a,"b b"][cc]something
这个字符串有个三个label:
a
b b
cc


例子6
[a,"b b",cc]something
这个字符串有个三个label:
a
b b
cc


例子7
[a,b b][cc]something
这个字符串有个四个label:
a
b
b
cc


需要支持全角比如"【】" label 分隔符","也要支持全角""
例如
a[b]somthing
 
这个字符串有个两个label:
a
b


ab[c]somthing
 
这个字符串有个三个label:
a
b
c


 


请用C#写一个分析字符串label的小函数
List parseLabels(string inputString)
根据输入的字符串返回字符串中含有的label
要求代码清晰,可读性好,如果算法比较复杂请给出适当的算法说明



最佳回答


我的解法如下:

 

Code

//引号与括号都是就近原则,即"adfa[[]]【aadfa"将拿到一个Label---"[",Label不会拿到空值"";除非在引号里面,否则也不会拿到",","]"
private static List<string> parseLabels(string inputString)
{
List
<string> list = new List<string>();
bool isInBracket = false;//是不是在括号里面
bool isInInvertedComma = false;//是不是在引号里面
string oneLabel = "";//存储一个Label,如果Label为空则不添加
foreach (char item in inputString)
{
if (item == '[' || item == '')
{
if (!isInBracket)//如果不在括号里面则开启括号,否则作为一个字符追加
isInBracket = true;
else
oneLabel
+= item;
}
else if (item == ']' || item == '')
{
if (isInInvertedComma)//如果在引号里面则追加,否则结束字符,并关闭括号
oneLabel += item;
else
{
isInBracket
= false;
if (oneLabel.Length != 0)
{
list.Add(oneLabel);
oneLabel
= "";
}
}
}
else if (item == ',' || item == '' || item == ' ')
{
if (isInBracket)//如果在括号里面并且在引号里面则追加,否则结束字符
{
if (isInInvertedComma)
oneLabel
+= item;
else if (oneLabel.Length != 0)
{
list.Add(oneLabel);
oneLabel
= "";
}
}
}
else if (item == '\"')
{
if (isInBracket)
{
if (isInInvertedComma)//如果引号开启则关闭,并且结束字符,否则开启,前提是前面没字符,有的话就追加
{
list.Add(oneLabel);
oneLabel
= "";
isInInvertedComma
= false;
}
else if (oneLabel == "")
{
isInInvertedComma
= true;
}
else
{
oneLabel
+= item;
}
}
}
else if (isInBracket)
oneLabel
+= item;
}
return list;
}

 

但有个小问题,因为是就近原则所以....
还是看下面这个吧

“["adfa,[[]]【aadfa】”我们希望是|"adfa|,|[[|,|aadfa|,但实际上他什么也拿不到因为引号没有结束,如果在最后面加个引号,他会拿到引号后面的所有,而实际上答案应该和上面的一样



推荐阅读
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 作为一名程序员,从大学步入职场后,常常感受到一种难以言喻的空虚感。这种感觉或许源于对生活的不满、职业发展的瓶颈,或是日常琐事带来的压力。本文将深入探讨这种复杂的情感,并尝试寻找解决之道。 ... [详细]
  • 深入解析:阿里实战 SpringCloud 微服务架构与应用
    本文将详细介绍 SpringCloud 在微服务架构中的应用,涵盖入门、实战和案例分析。通过丰富的代码示例和实际项目经验,帮助读者全面掌握 SpringCloud 的核心技术和最佳实践。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文深入探讨了C++对象模型中的一些细节问题,特别是虚拟继承和析构函数的处理。通过具体代码示例和详细分析,揭示了书中某些观点的不足之处,并提供了更合理的解释。 ... [详细]
  • 随着网络安全威胁的不断演变,电子邮件系统成为攻击者频繁利用的目标。本文详细探讨了电子邮件系统中的常见漏洞及其潜在风险,并提供了专业的防护建议。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 深入理解Spring:Aware接口、异步编程与计划任务
    本文将带你深入了解Spring框架中的 Aware 接口、异步编程以及计划任务。通过具体示例和详细解释,帮助你掌握这些核心功能的实现原理和应用场景。 ... [详细]
  • TechStride 网站
    TechStride 成立于2014年初,致力于互联网前沿技术、产品创意及创业内容的聚合、搜索、学习与展示。我们旨在为互联网从业者提供更高效的新技术搜索、学习、分享和产品推广平台。 ... [详细]
  • 网易严选Java开发面试:MySQL索引深度解析
    本文详细记录了网易严选Java开发岗位的面试经验,特别针对MySQL索引相关的技术问题进行了深入探讨。通过本文,读者可以了解面试官常问的索引问题及其背后的原理。 ... [详细]
  • 前端开发:从底层到顶端的行业现象解析
    在编程领域,鄙视链现象屡见不鲜,从C语言到Java、.NET等,每个技术栈都有其独特地位。然而,前端开发者尽管常处于鄙视链底端,却在市场需求中备受青睐。本文深入探讨这一现象,并分析前端工程师如何在竞争激烈的市场中脱颖而出。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
author-avatar
手机用户2502903481
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有