字符串比较-面试题

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

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

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

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

  • 一开始的思路是用A的每一位去和B的每一位去比较。
    如果说B每一位都能在A中找到的话,则A中包含B。
    代码如下:
    bool compareStrings(string A, string B) {
    int countA = A.length();
    int countB = B.length();
    int sub = 0;
    int temp[countB];
    for (int i = 0; i < countB; i++) {
    temp[i]=0;
    }
    for (int i = 0; i < countA; i++) {
    for (int n = 0; n < countB; n++) {
    if ( A[i] == B[n]) {
    temp[n] = 1;
    }
    }
    }
    for (int i = 0; i < countB; i++) {
    sub = temp[i] + sub;
    }
    if (sub == countB)
    return true;
    else
    return false;
    }

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

  • 所以这次改进代码,避免一个字符的多次判定。
    要做的很简单,在判定存在的语句后面加上一个break。

     for (int i = 0; i < countA; i++) {
         for (int n = 0; n < countB; n++) {
             if ( A[i] == B[n]) {
             temp[n] = 1;
             break;
             }
         }
     }
    

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

  • ……很无奈接着补充代码:

     for (int i = 0; i < countA; i++) {
         for (int n = 0; n < countB; n++) {
             if ( A[i] == B[n]) {
             temp[n] = 1;
             if ( A[i] != A[i-1])//当A的后一个字符与前一个不一样时才跳出循环
             break;
             }
         }
     }
    

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

思路如下:

  • 统计两边的信息进行比较。如果B中的每种字符的个数小于等于A中的,则A包含B。
    代码如下:
    int Achar[26];//储存字符串的每个字母个数
    int Bchar[26];
    for (int i = 0; i<26; i++) {
    Achar[i] = 0;
    Bchar[i] = 0;
    }
    int Adate,Bdate;//记录AB的字符统计数据
    int countA = A.length();
    int countB = B.length();
    for (int i = 0; i<countA; i++) {
    int index;
    index = A[i] - 65;
    Achar[index]++;
    }
    for (int i = 0; i<countB; i++) {
    int index;
    index = B[i] - 65;//65为大写A的ASCⅡ码值
    Bchar[index]++;
    }
    for (int i = 0; i<26; i++) {
    if (Achar[i]<Bchar[i])
    return false;
    }
    return true;
    }

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容