diff函数的实现——LCS的变种问题

  昨天去去哪儿笔试,碰到了一个我们一直很熟悉的命令(diff——ubuntu下面),可以比较字符串,即根据最长公共子串问题,如果A中有B中没有的字符输出形式如下(-ch),如果A中没有,B中有可以输出如下形式(+ch).

 

#include <iostream>
#include <cstring>
#include <vector>
using namespace std;

string LCS(string &s1, string &s2)
{
    int row = s1.size();
    int col = s2.size();
    string table[row + 1][col + 1];
    char rowChar[row + 1];
    char colChar[col + 1];
    int cnt = 0;
    rowChar[0] = colChar[0] = '\0';
    for(int i = row - 1, cnt = 1; i >= 0; i--, cnt++)
    {
        rowChar[cnt] = s1[i];
    }
    for(int i = col - 1, cnt = 1; i >= 0; i--, cnt++)
    {
        colChar[cnt] = s2[i];
    }
    char ch1, ch2;
    string str1, str2;
    for(int i = 1; i <= row; i++)
    {
        for(int j = 1; j <= col; j++)
        {
            ch1 = rowChar[i];
            ch2 = colChar[j];
            if(ch1 == ch2)
                table[i][j] = ch1 + table[i - 1][j - 1];
            else
            {
                str1 = table[i - 1][j];
                str2 = table[i][j - 1];
                if(str1.size() == str2.size())
                    table[i][j] = str1 < str2 ? str2 : str1;
                else
                    table[i][j] = str1.size() < str2.size() ? str2 : str1;
            }
        }
    }
    return table[row][col];
}
void showDiff(string &s1, string &s2, string sub, vector<string> &ret)
{
    cout << "Sub = " << sub << endl;
    int len1 = s1.size();
    int len2 = s1.size();
    for(int i = 0, j = 0; i < len1; i++)
    {
        if(s1[i] != sub[j])
        {
            string str;
            str.push_back('-');
            str.push_back(s1[i]);
            ret.push_back(str);
        }
        else
            j++;
    }
    for(int i = 0, j = 0; i < len2; i++)
    {
        if(s2[i] != sub[j])
        {
            string str;
            str.push_back('+');
            str.push_back(s2[i]);
            ret.push_back(str);
        }
        else
            j++;
    }
}

int main()
{
    string str1, str2;
    cin >> str1 >> str2;
    string retSub = LCS(str1, str2);
    vector<string> ret;
    showDiff(str1, str2, retSub, ret);
    vector<string>::iterator iter;
    for(iter = ret.begin(); iter != ret.end(); iter++)
        cout << *iter << endl;
    return 0;
}

 

posted @ 2014-09-23 09:51  Awy  阅读(540)  评论(3编辑  收藏  举报