最后
🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
public int top() {
return stack.peek();
}
public int getMin() {
return minStack.peek();
}
}
## 第二题:[20. 有效的括号](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/d3286c2c79e54513a406854ecab4ac18.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
代码实现
class Solution {
public boolean isValid(String s) {
Stack stack=new Stack<>();
for(int i=0;i<s.length();i++){
char c= s.charAt(i);
//左括号进栈
if(c==‘(’||c==‘{’||c==‘[’){
stack.push©;
}
else{
if(stack.isEmpty()){return false;}
Character topChar=stack.pop();
//右括号进行判断,若不同类型返回false;
if(c==‘)’&&topChar!=‘(’){
return false;
}
if(c==‘]’&&topChar!=‘[’){
return false;
}
if(c==‘}’&&topChar!=‘{’){
return false;
}
}
}
return stack.isEmpty();
}
}
## 第三题:[225. 用队列实现栈](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/11ce607b7a5d4d078674d4ff2b855d43.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
代码实现
class MyStack {
//用两个队列来实现栈
Queue queue1;
Queue queue2;
public MyStack() {
queue1 = new LinkedList<Integer>();
queue2 = new LinkedList<Integer>();
}
public void push(int x) {
//当为空的时候,插入x
queue2.offer(x);
while (!queue1.isEmpty()) {
queue2.offer(queue1.poll());
}
Queue<Integer> temp = queue1;
queue1 = queue2;
queue2 = temp;
}
public int pop() {
return queue1.poll();
}
public int top() {
return queue1.peek();
}
public boolean empty() {
return queue1.isEmpty();
}
}
## 第四题:[232. 用栈实现队列](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/0e248b3ff0844305bc480eb2433d3acb.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
代码实现
class CQueue {
//创建两个栈
Stack stack1;
Stack stack2;
public CQueue() {
stack1=new Stack();
stack2=new Stack();
}
public void appendTail(int value) {
//入队直接压入栈中
stack1.push(value);
}
public int deleteHead() {
if(stack2.empty()){
while(!stack1.empty()){
stack2.push(stack1.pop());
}
}
if(stack2.empty()){
return -1;
}
return stack2.pop();
}
}
## 第五题:[622. 设计循环队列](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/71f3b7419fc249339d7f0cff4350c3da.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
代码实现
class MyCircularQueue {
final int[] array;
final int k;
int left;//指向队首元素
int right;
public MyCircularQueue(int k) {
this.array=new int[k];
this.k=k;
Arrays.fill(array,-1);
left=k;
right=k;
}
public boolean enQueue(int value) {
if(isFull())return false;
else{
array[right%k]=value;
right++;
return true;
}
}
public boolean deQueue() {
if(isEmpty())return false;
else{
array[left%k]=-1;
left++;
return true;
}
}
public int Front() {
if(isEmpty())return -1;
return array[left%k];
}
public int Rear() {
if(isEmpty())return -1;
//(right-1)%k 防止数组越界 right%k-1会越界
else return array[(right-1)%k];
}
public boolean isEmpty() {
if(left==right)return true;
return false;
}
public boolean isFull() {
if(right-left==k)return true;
return false;
}
}
## 第六题[:1470. 重新排列数组](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/567147f17c3d4a92bfd288e91b699a8e.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
代码实现
class Solution {
public int[] shuffle(int[] nums, int n) {
int[] arr=new int[2n];
for(int i=0;i<n;i++){
arr[2i]=nums[i];
arr[2*i+1]=nums[i+n];
}
return arr;
}
}
## 第七题:[1929. 数组串联](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/8572c261e27a4d25875a5aad8f950b7b.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
代码实现
class Solution {
public int[] getConcatenation(int[] nums) {
int n = nums.length;
int[] ans = new int[n * 2];
for(int i = 0; i < n; i++){
ans[i] = nums[i];
ans[i + n] = nums[i];
}
return ans;
}
}
## 第八题:[1920. 基于排列构建数组](https://bbs.csdn.net/topics/618317507)
![](https://img-blog.csdnimg.cn/a65edf3db1604c419d763b99e62fd4dd.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6b6N5byfLWlkZWE=,size_20,color_FFFFFF,t_70,g_se,x_16)
### 最后
Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
#### 👉Python所有方向的学习路线👈
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
![](https://img-blog.csdnimg.cn/img_convert/604bae65027d4d67fb62410deb210454.png)
#### 👉Python必备开发工具👈
工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
![](https://img-blog.csdnimg.cn/img_convert/fa276175617e0048f79437bd30465479.png)
#### 👉Python全套学习视频👈
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
![](https://img-blog.csdnimg.cn/img_convert/16ac689cb023166b2ffa9c677ac40fc0.png)
#### 👉实战案例👈
学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。
因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。
![](https://img-blog.csdnimg.cn/img_convert/0d8c31c50236a205928a1d8ae8a0b883.png)
#### 👉大厂面试真题👈
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
![](https://img-blog.csdnimg.cn/img_convert/99461e47e58e503d2bc1dc6f4668534a.png)
**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618317507)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**