C语言数组合并的方法有以下几种:
int mergeArrays(int arr1[], int arr2[], int len1, int len2, int merged[]) {
int i, j, k;
// 复制数组 arr1 的元素到 merged
for (i = 0; i < len1; i++) {
merged[i] = arr1[i];
}
// 复制数组 arr2 的元素到 merged
for (j = 0, k = len1; j < len2; j++, k++) {
merged[k] = arr2[j];
}
return len1 + len2; // 返回合并后数组的长度
}
int mergeArrays(int arr1[], int arr2[], int len1, int len2, int merged[]) {
int i, j;
// 复制数组 arr1 的元素到 merged
for (i = 0; i < len1; i++) {
*merged++ = arr1[i];
}
// 复制数组 arr2 的元素到 merged
for (j = 0; j < len2; j++) {
*merged++ = arr2[j];
}
return len1 + len2; // 返回合并后数组的长度
}
memcpy()
或 memmove()
,将两个数组的元素复制到一个新的数组中。#include <string.h>
int mergeArrays(int arr1[], int arr2[], int len1, int len2, int merged[]) {
memcpy(merged, arr1, len1 * sizeof(int)); // 复制数组 arr1 的元素到 merged
memcpy(merged + len1, arr2, len2 * sizeof(int)); // 复制数组 arr2 的元素到 merged
return len1 + len2; // 返回合并后数组的长度
}
这些方法都可以实现数组的合并,具体选择哪种方法取决于实际需求和个人偏好。