91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言字符串中的動態規劃應用

發布時間:2024-08-30 09:36:01 來源:億速云 閱讀:97 作者:小樊 欄目:編程語言

在C語言中,字符串是一個非常重要的數據類型,而動態規劃是一種解決復雜問題的方法。在處理字符串時,動態規劃可以幫助我們找到最優解,例如在編輯距離、最長公共子序列等問題中。

下面是一個使用動態規劃解決字符串相關問題的例子:編輯距離(Levenshtein距離)。

編輯距離是指將一個字符串轉換為另一個字符串所需的最少操作次數。允許的操作包括插入、刪除和替換一個字符。我們可以使用動態規劃來計算兩個字符串之間的編輯距離。

#include<stdio.h>
#include<string.h>
#include <stdlib.h>

int min(int a, int b) {
    return a < b ? a : b;
}

int edit_distance(const char *str1, const char *str2) {
    int len1 = strlen(str1);
    int len2 = strlen(str2);
    int **dp = (int **)malloc((len1 + 1) * sizeof(int *));
    for (int i = 0; i <= len1; i++) {
        dp[i] = (int *)malloc((len2 + 1) * sizeof(int));
    }

    for (int i = 0; i <= len1; i++) {
        dp[i][0] = i;
    }
    for (int j = 0; j <= len2; j++) {
        dp[0][j] = j;
    }

    for (int i = 1; i <= len1; i++) {
        for (int j = 1; j <= len2; j++) {
            if (str1[i - 1] == str2[j - 1]) {
                dp[i][j] = dp[i - 1][j - 1];
            } else {
                dp[i][j] = min(min(dp[i - 1][j], dp[i][j - 1]), dp[i - 1][j - 1]) + 1;
            }
        }
    }

    int result = dp[len1][len2];
    for (int i = 0; i <= len1; i++) {
        free(dp[i]);
    }
    free(dp);
    return result;
}

int main() {
    const char *str1 = "kitten";
    const char *str2 = "sitting";
    printf("編輯距離: %d\n", edit_distance(str1, str2));
    return 0;
}

這個程序首先計算兩個字符串的長度,然后創建一個動態規劃表格,用于存儲子問題的解。接下來,我們初始化表格的第一行和第一列,表示將一個空字符串轉換為另一個字符串所需的操作次數。然后,我們遍歷兩個字符串,比較它們的每個字符,根據動態規劃的狀態轉移方程更新表格。最后,我們返回表格右下角的值,即兩個字符串之間的編輯距離。

這個例子展示了如何在C語言中使用動態規劃解決字符串相關問題。當然,還有很多其他字符串問題可以使用動態規劃來解決,例如最長公共子序列、最長公共子串等。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

民勤县| 新竹县| 泊头市| 阿图什市| 当阳市| 格尔木市| 海原县| 惠水县| 韶山市| 旌德县| 漳浦县| 河北省| 长寿区| 丽水市| 库车县| 辉县市| 出国| 宜黄县| 舟曲县| 临澧县| 治多县| 沁水县| 襄樊市| 苍梧县| 宁河县| 乐安县| 通山县| 河池市| 天等县| 綦江县| 井研县| 慈利县| 罗源县| 图们市| 咸丰县| 云霄县| 化隆| 新邵县| 宝丰县| 精河县| 松溪县|