您好,登錄后才能下訂單哦!
在C語言中,沒有內置的函數來直接替換字符串中的特定模式
#include<stdio.h>
#include<string.h>
#include <stdlib.h>
char *replace_pattern(const char *str, const char *pattern, const char *replacement) {
size_t pattern_len = strlen(pattern);
size_t replacement_len = strlen(replacement);
size_t count = 0;
const char *ptr;
// 計算模式出現的次數
for (ptr = str; (ptr = strstr(ptr, pattern)); ptr += pattern_len) {
count++;
}
// 如果模式未找到,直接返回原字符串的副本
if (count == 0) {
return strdup(str);
}
// 計算替換后的字符串長度
size_t new_len = strlen(str) + (replacement_len - pattern_len) * count;
char *result = (char *)malloc(new_len + 1);
// 初始化結果字符串
char *dest = result;
for (ptr = str; *ptr;) {
if (strncmp(ptr, pattern, pattern_len) == 0) {
// 將替換字符串復制到結果字符串
memcpy(dest, replacement, replacement_len);
dest += replacement_len;
ptr += pattern_len;
} else {
// 將原字符復制到結果字符串
*dest++ = *ptr++;
}
}
*dest = '\0';
return result;
}
int main() {
const char *str = "Hello, world! I love this world.";
const char *pattern = "world";
const char *replacement = "planet";
char *result = replace_pattern(str, pattern, replacement);
printf("Original string: %s\n", str);
printf("Replaced string: %s\n", result);
free(result);
return 0;
}
這個示例中的replace_pattern
函數接受三個參數:原始字符串、要替換的模式和替換字符串。它首先計算模式在原始字符串中出現的次數,然后分配足夠的內存來存儲替換后的字符串。最后,它遍歷原始字符串,將找到的模式替換為指定的替換字符串,并將結果存儲在新的字符串中。
請注意,這個示例沒有處理一些邊緣情況,例如內存分配失敗。在實際應用中,你可能需要添加錯誤檢查和處理。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。