亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

如何比較兩個C語言字符串的相似性

發布時間:2024-08-30 12:37:52 來源:億速云 閱讀:89 作者:小樊 欄目:編程語言

要比較兩個C語言字符串的相似性,可以使用一種稱為“編輯距離”(Edit Distance)的算法

#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] = 1 + min(min(dp[i - 1][j], dp[i][j - 1]), dp[i - 1][j - 1]);
            }
        }
    }

    int distance = dp[len1][len2];

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

    return distance;
}

int main() {
    const char *str1 = "kitten";
    const char *str2 = "sitting";

    printf("Edit distance between '%s' and '%s': %d\n", str1, str2, edit_distance(str1, str2));

    return 0;
}

這個程序首先計算輸入字符串的長度,并分配一個動態二維數組來存儲中間結果。接下來,它初始化第一行和第一列的值,然后遍歷每個字符,計算編輯距離。最后,返回dp[len1][len2]作為結果,并釋放分配的內存。

在這個例子中,我們計算了字符串 “kitten” 和 “sitting” 之間的編輯距離。運行此程序將輸出:

Edit distance between 'kitten' and 'sitting': 3

這意味著只需要3次操作(插入、刪除或替換)就可以將一個字符串轉換為另一個字符串。

向AI問一下細節

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

AI

南涧| 蒙山县| 崇礼县| 吉安市| 咸宁市| 双辽市| 磐石市| 壶关县| 堆龙德庆县| 鄯善县| 玉林市| 娱乐| 获嘉县| 临汾市| 宁南县| 石柱| 井冈山市| 顺昌县| 瓦房店市| 临汾市| 外汇| 乌拉特前旗| 六盘水市| 黄浦区| 辽中县| 密山市| 南陵县| 乾安县| 张掖市| 武威市| 从江县| 桂东县| 苏州市| 博湖县| 汤阴县| 彰化县| 安陆市| 镇沅| 齐河县| 平乡县| 渭南市|