#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.Поиск числа сравнения в LCS При динамическом программировании
Я хочу найти общий номер. сравнений и распечатать его с использованием глобальной переменной счетчика. Может ли кто-нибудь помочь мне?
Я хочу, чтобы вычислить comparision это займет? –
@NamitPathak: вам также придется увеличивать и другие места. Как, например, в цикле for. Снова вы можете создать дополнительную функцию и поместить ее в свое условие цикла, например: 'for (int i = 0; leq (i, m); i ++)'. Функция 'leq' (меньше или равно) также увеличивала бы счетчик, а затем возвращала бы bool, было ли сравнение истинным или нет. Аналогично для 'i == 0' вам понадобится нечто вроде' isZero (i) '. Вам также необходимо увеличить значение 'max'. Фактически, вам нужно будет заменить * все * сравнения на функции, где вы сначала увеличиваете счетчик, а затем сравниваете. – dingalapadum
@NamitPathak: Если вы хотите посчитать все * cpu сравнения, он станет немного более волосатым. Я не совсем уверен, как подсчитать сравнения, происходящие в библиотечных функциях, таких как 'cout'. Я бы попытался: скопировать программу статически ('-статический'), а затем с флагом' -S', чтобы увидеть сборку. Затем найдите все инструкции, которые выполняют сравнение и увеличивают счет прямо перед каждым из них. Но я не совсем уверен в этом. Во всяком случае, я думаю, что это гораздо более широкий вопрос, который, вероятно, заслуживает собственного вопроса и ответа, независимо от проблемы. Вы хотите спросить? Или я должен это делать? – dingalapadum