【问题标题】:Finding Number of Comparison in LCS In dynamic programming在动态规划中查找 LCS 中的比较数
【发布时间】:2015-10-15 15:18:47
【问题描述】:
#include<iostream>
#include<string.h>
int count=0;

using namespace std;


int max(int a,int b)
{
    return (a>b)?a:b;
}

int lcs(char *x,char*y ,int m,int n)
{

    int l[m+1][n+1];
    int i,j;

    for( i=0;i<=m;i++)
    {
     for(j=0;j<=n;j++)
        {

        if(i==0 || j==0)
        l[i][j]=0;

        else if(x[i-1]==y[j-1]) 
        l[i][j]=l[i-1][j-1]+1;

        else
        l[i][j] =max(l[i-1][j], l[i][j-1]);

        }
    }


    return l[m][n];


}


int main()
{

    char x[]="AGGTAB";
    char y[]="GXTXAYB";

    int m=strlen(x);
    int n=strlen(y);

    cout<<"The Length Of the Longest Common Subsequence Is  :   "<<lcs(x,y,m,n);
}

上述程序用于使用动态规划找到最大公共子序列解决方案。 我能够计算 LCS 的长度,但我无法推断找到总数的逻辑。系统将进行比较以找到 lcs。

我想找到总数。比较并使用全局计数变量打印它。有人可以帮我吗?

【问题讨论】:

    标签: c++ data-structures dynamic-programming lcs


    【解决方案1】:

    这取决于您将什么视为比较。

    我假设,通过比较您的意思是“比较字符串中的字符”。 IE。 i==0 算作比较。此外,比较 max 中的值也不算作比较,因为它确实 not 比较字符串中的字符。此外,我没有通过您的程序检查您所做的是否真的正确 - 我只是假设它是并专注于您的实际问题。

    话虽如此,正在发生的字符的唯一比较是在该行中:

    else if(x[i-1]==y[j-1]) 
    

    因此,每次执行此检查时,都应增加计数器。一种方法是稍微重组你的分支(而不是else if,你可以做一个else{ if{x[i-1]==y[j-1]} }。如果你这样做,那么你可以在if之前增加counter。就像这样:

    if(){
    
    }else{ 
     counter++;
     if{x[i-1]==y[j-1]} 
    
     }else{
    
     }
    }
    

    另一种更明确的方法是让一个函数在那里进行检查和递增。比如:

    bool compareChars(char &first, char &second){
     counter++;
     return first == second;
    }
    

    然后你会这样做:

    else if(compareChars(x[i-1], y[j-1]))
    

    那么很明显,每次进行比较时,计数器都会递增。

    我没有彻底测试这个,当然其他方法也是可能的,但我还是希望你能大致了解一下。

    【讨论】:

    • 我想计算它需要的cpu​​ comaparision?
    • @NamitPathak :您也必须在其他地方增加。例如在 for 循环中。同样,您可以创建一个附加函数并将其放入循环条件中,如下所示:for(int i=0; leq(i, m); i++)。然后函数leq(小于或等于)也会增加计数器,然后返回一个布尔值,无论比较是否为真。同样对于i==0,您将需要类似isZero(i) 的内容。您还需要增加max。实际上,您需要将 all 比较替换为首先递增计数器然后进行比较的函数。
    • @NamitPathak :如果你想计算 all cpu 比较,它会变得有点毛茸茸。我不太确定如何计算 cout 等库函数中发生的比较。我会尝试的是:静态编译程序(-static),然后使用-S 标志来查看程序集。然后查找所有进行比较的指令,并在每个指令之前增加计数。但我不太确定这一点。无论如何,我认为这是一个更广泛的问题,可能值得独立于问题提出自己的问题和答案。你想问吗?还是我应该这样做?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2020-05-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-03-23
    • 2019-08-17
    • 2017-02-06
    相关资源
    最近更新 更多