既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
+ [对应题解](#_12)
数组中重复的数字
题目及要求
对应题解
正解:
class Solution {
public:
/\*\*
\* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
\*
\* @param numbers int整型vector
\* @return int整型
\*/
int duplicate(vector<int>& numbers) {
// write code here
if(numbers.size()==0)
return -1;
sort(numbers.begin(),numbers.end());
for(int i=0;i<numbers.size()-1;i++){
if(numbers[i]==numbers[i+1]){
return numbers[i];
}
}
return -1;
}
};
分析:
这个题目一定要好好分析,题目中说的是返回任意一个重复元素,当然可以选择两重循环来找重复的元素,但是那样效率实在不高。所以我就想用
一重循环
来解决,怎么做呢?那就是先对容器内元素排序
,然后从第一个元素开始两两比较,只要有相同结果出现就返回该元素值。但是一定要注意数组越界情况,先把数组为空
的情况考虑并解决掉,然后一重循环中数组长度需要减一,防止条件里i+1
导致数组越界。
二维数组中的查找
题目及要求
对应题解
正解:
class Solution {
public:
bool Find(int target, vector<vector<int> > array) {
for(vector<vector<int>>::iterator T=array.begin();T!=array.end();T++){
for(vector<int>::iterator t=(\*T).begin();t!=(\*T).end();t++){
if(\*t==target)
return true;
}
}
return false;
}
};
分析:
这个题考察二维数组的
遍历
,不过是题目给的是容器嵌套
的形式,那就要靠你对容器迭代知识的理解了。外层for循环使用迭代器T
,内层使用迭代器t
,前面文章提到迭代器相当于指针,那么*T
就是内层的t,也就是T指向t的地址。通过解引用
就可以得到对应的值,同理,*t
就代表容器内的元素值。
替换空格
题目及要求
对应题解
正解:
class Solution {
public:
/\*\*
\* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
\*
\* @param s string字符串
\* @return string字符串
\*/
string replaceSpace(string s) {
// write code here
string res="";
for(int i=0;i<s.length();i++){
if(s[i]!=' ')
res +=s[i];
else
res +="%20";
}
return res;
}
};
分析:
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
识点,真正体系化!**
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新