Hello World!程序员数据结构

字符串比较-面试题

2015-06-15  本文已影响1870人  loveforkeeps

这是近几天在LintCode上遇到的一道题,题目如下:

比较两个字符串A和B,确定A中是否包含B中所有的字符。字符串A和B中的字符都是大写字母:

给出 A = "ABCD" B = "AABC", 返回 false

给出 A = "ABCD" B = "ACD",返回 true

但是在遇到B的字符里有A的重复个的时候:
"ABCDEFG", "ACC"
A的同一个C会在B中判断两次,导致输出的结果为true,但其实应该为false。

就像上面提到的情况,问题又出现了:
"AAAAAAAAAAAABBBBBCDD", "ABCDD"(true)
A的DD在B中只判定了B的第一个D,就跳出了,所以输出为false。

好吧,糟糕的情况又出现了。
"AAAAAAAAAAAAAAAAAAABBBBBBBBBDFADSFJALSDJFALSDJFSADFADF", "AAAAAABBBBBBBBBDFJALDJF"(true)
这里又错误的返回了一个fasle,由于A中的D并不是连续,所以和上面的错误类似,B中的第二个D不能得到判定。
做到这里就不得不说下了,像你已经看到这种修修补补的代码,一般情况下都是很糟糕的,而且问题较多。因为必须要顺着前面的思路,来解决后面的问题 ,你很有可能发现之前的算法结构在解决后面出现问题时是异常困难的。最好构造算法之前就要考虑到最坏的情况,或者说最后重构下自己的代码。
由于我一开始看到题目中给的的数据很简单就没考虑到现在的情况。
我觉得我的方法需要换一种了。

思路如下:

这一次19个测试数据全部通过。😄

上一篇 下一篇

猜你喜欢

热点阅读