c语言练习62:数组串联

数组串联

给你一个长度为 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
int* getConcatenation1(int* nums, int numsSize, int* returnSize) {
	int* ans = (int*)malloc(sizeof(int)*(2* numsSize));
	int i = 0;
	for (i = 0; i < numsSize; i++) {
		ans[i] = nums[i];
		ans[i + numsSize] = nums[i];
	}
	*returnSize = 2 * numsSize;
	return ans;
}
int* getConcatenation(int* nums, int numsSize, int* returnSize) {
	int* nums = (int*)realloc(sizeof(int) * 2 * numsSize);
	int i = 0;
	for (i = 0; i < numsSize; i++) {
		nums[i + numsSize] = nums[i];
	}
	*returnSize = 2 * numsSize;
	return nums;
}

 

c语言练习62:数组串联_第1张图片

 

 

你可能感兴趣的:(c语言,算法,数据结构)