既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
输入:
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
分析
- 参数长度不可变
- 按着题意,直接新建2倍大数组,然后循环2 * n次,按顺序赋值。
- 由于结果是入参重复2次,所以也可以直接循环n次,每次赋值2个结果。
- 参数长度可变
- 直接在参数后面,重复一遍自己,然后返回即可。
题解
java
public class Solution {
public int[] getConcatenation(int[] nums) {
// 原数组长度
final int n = nums.length;
// 结果数组长度
final int m = n \* 2;
int[] ans = new int[m];
for (int i = 0; i < m; ++i) {
ans[i] = nums[i % n];
}
return ans;
}
}
class Solution {
public int[] getConcatenation(int[] nums) {
// 原数组长度
final int n = nums.length;
int[] ans = new int[n \* 2];
for (int i = 0; i < n; ++i) {
ans[i] = ans[i + n] = nums[i];
}
return ans;
}
}
c
/\*\*
\* Note: The returned array must be malloced, assume caller calls free().
\*/
int\* getConcatenation(int\* nums, int numsSize, int\* returnSize){
int \*ans = malloc(sizeof(int) \* numsSize \* 2);
for (int i = 0; i < numsSize; ++i) {
ans[i] = ans[i + numsSize] = nums[i];
}
\*returnSize = numsSize \* 2;
return ans;
}
c++
class Solution {
public:
vector<int> getConcatenation(vector<int>& nums) {
nums.insert(nums.end(), nums.begin(), nums.end());
return nums;
}
};
python
class Solution:
def getConcatenation(self, nums: List[int]) -> List[int]:
nums.extend(nums)
return nums
go
func getConcatenation(nums []int) []int {
return append(nums, nums...)
}
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
那么很难做到真正的技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!