C# Dynami c преобразование программирования - PullRequest
1 голос
/ 26 мая 2020

Привет, у меня есть задача преобразовать экспоненциальный код в линейный, но я не знаю, как это сделать. Не могли бы вы дать мне какие-нибудь советы или указать правильное направление?

Вот код:

        int F (int m, int n)
        {
            if(n == 0)
            {
                return m;
            }

            else if(m == 0 && n > 0)
            {
                return n;
            }

            else
            {
                int[] array = { 1 + F(m - 1, n), 1 + F(m, n - 1), D(m, n) + F(m - 1, n - 1) };
                return array.Min();
            }
        }

        int D(int i, int f)
        {
            if(x[i] == y[f])
            {
                return 1;
            }
            else
            {
                return 0;
            }
        }

Обновление:

Я иду в правильном направлении? Пока работает только с m = 0,1,2 и n = 0,1,2. Как мне заполнить все значения, если, скажем, я даю m = 10 и n = 20?

int Fdp(int m, int n)
        {
            fdin[m, 0] = m;

            for(int i = 0; i <= n; i++)
            {
                fdin[0, i] = n;
            }

            if (n == 0)
            {
                return m;
            }

            else if (m == 0 && n > 0)
            {
                return n;
            }

            else
            {

                int[] temp = { 1 + fdin[m-1, n], 1+ fdin[m,n-1], D(m,n) + fdin[m-1,n-1] };
                fdin[m, n] = temp.Min();
                return temp.Min();
            }

        }

1 Ответ

0 голосов
/ 26 мая 2020

Решил.

        static int Fdp(int m, int n)
        {
            for (int i = 0; i <= m; i++)
            {
                fdin[i, 0] = i;
                for (int j = 1; j <= n; j++)
                {
                    if(i == 0)
                    {
                        fdin[i, j] = j;
                    }
                    else
                    {
                        int[] temp = new int[] { 1 + fdin[i - 1, j], 1 + fdin[i, j - 1], D(i, j) + fdin[i - 1, j - 1] };
                        fdin[i, j] = temp.Min();
                    }
                }
            }
            return fdin[m,n];
        }
...