1929. 数组串联
给你一个长度为 n 的整数数组 nums 。请你构建一个长度为 2n 的答案数组 ans ,数组下标 从 0 开始计数 ,对于所有 0 <= i < n 的 i ,满足下述所有要求:ans[i] == nums[i]
ans[i + n] == nums[i],具体而言,ans 由两个 nums 数组 串联 形成。返回数组 ans 。
示例 1:输入:nums = [1,2,1],输出:[1,2,1,1,2,1],解释:数组 ans 按下述方式形成:
- ans = [nums[0],nums[1],nums[2],nums[0],nums[1],nums[2]]
- ans = [1,2,1,1,2,1]
示例 2:输入:nums = [1,3,2,1],输出:[1,3,2,1,1,3,2,1],解释:数组 ans 按下述方式形成:
- ans = [nums[0],nums[1],nums[2],nums[3],nums[0],nums[1],nums[2],nums[3]]
- ans = [1,3,2,1,1,3,2,1]
提示:n == nums.length,1 <= n <= 1000,1 <= nums[i] <= 1000
#include <stdio.h>
#include <stdlib.h>
int* getConcatenation(int* nums, int numsSize, int* returnSize) {
*returnSize = 2 * numsSize;
int* ans = (int*)malloc(*returnSize * sizeof(int));
for (int i = 0; i < numsSize; i++) {
ans[i] = nums[i];
ans[i + numsSize] = nums[i];
}
return ans;
}
int main() {
int nums[] = {1, 2, 1};
int numsSize = sizeof(nums) / sizeof(nums[0]);
int returnSize;
int* ans = getConcatenation(nums, numsSize, &returnSize);
printf("Output: ");
for (int i = 0; i < returnSize; i++) {
printf("%d ", ans[i]);
}
printf("\n");
free(ans);
return 0;
}
定义一个名为`getConcatenation`的函数,它接受一个整数数组`nums`、数组大小`numsSize`和一个指向整数的指针`returnSize`。该函数返回一个长度为`2 * numsSize`的整数数组`ans`,其中`ans`由两个`nums`数组串联形成。
在`main`函数中,我们定义了一个示例数组`nums`,然后调用`getConcatenation`函数来获取答案数组`ans`。最后,我们打印输出`ans`数组的元素。