This commit is contained in:
programmercarl
2022-06-10 11:02:44 +08:00
parent b96175b7a3
commit f5f5f5a2a5
7 changed files with 460 additions and 8 deletions

View File

@ -28,6 +28,8 @@
## 思路 ## 思路
[本题B站视频讲解](https://www.bilibili.com/video/BV12A4y1Z7LP)
有的同学可能说了,多余的元素,删掉不就得了。 有的同学可能说了,多余的元素,删掉不就得了。
**要知道数组的元素在内存地址中是连续的,不能单独删除数组中的某个元素,只能覆盖。** **要知道数组的元素在内存地址中是连续的,不能单独删除数组中的某个元素,只能覆盖。**
@ -75,10 +77,20 @@ public:
双指针法(快慢指针法): **通过一个快指针和慢指针在一个for循环下完成两个for循环的工作。** 双指针法(快慢指针法): **通过一个快指针和慢指针在一个for循环下完成两个for循环的工作。**
定义快慢指针
* 快指针:寻找新数组的元素 ,新数组就是不含有目标元素的数组
* 慢指针:指向更新 新数组下标的位置
很多同学这道题目做的很懵,就是不理解 快慢指针究竟都是什么含义,所以一定要明确含义,后面的思路就更容易理解了。
删除过程如下: 删除过程如下:
![27.移除元素-双指针法](https://tva1.sinaimg.cn/large/008eGmZEly1gntrds6r59g30du09mnpd.gif) ![27.移除元素-双指针法](https://tva1.sinaimg.cn/large/008eGmZEly1gntrds6r59g30du09mnpd.gif)
很多同学不了解
**双指针法(快慢指针法)在数组和链表的操作中是非常常见的,很多考察数组、链表、字符串等操作的面试题,都使用双指针法。** **双指针法(快慢指针法)在数组和链表的操作中是非常常见的,很多考察数组、链表、字符串等操作的面试题,都使用双指针法。**
后序都会一一介绍到,本题代码如下: 后序都会一一介绍到,本题代码如下:
@ -104,8 +116,6 @@ public:
* 时间复杂度O(n) * 时间复杂度O(n)
* 空间复杂度O(1) * 空间复杂度O(1)
旧文链接:[数组:就移除个元素很难么?](https://programmercarl.com/0027.移除元素.html)
```CPP ```CPP
/** /**
* 相向双指针方法,基于元素顺序可以改变的题目描述改变了元素相对位置,确保了移动最少元素 * 相向双指针方法,基于元素顺序可以改变的题目描述改变了元素相对位置,确保了移动最少元素

View File

@ -73,8 +73,8 @@ public:
}; };
``` ```
* 时间复杂度:$O(n)$ * 时间复杂度O(n)
* 空间复杂度:$O(1)$ * 空间复杂度O(1)
效率如下: 效率如下:
@ -135,14 +135,14 @@ public:
// 目标值在数组所有元素之前 [0, -1] // 目标值在数组所有元素之前 [0, -1]
// 目标值等于数组中某一个元素 return middle; // 目标值等于数组中某一个元素 return middle;
// 目标值插入数组中的位置 [left, right]return right + 1 // 目标值插入数组中的位置 [left, right]return right + 1
// 目标值在数组所有元素之后的情况 [left, right] return right + 1 // 目标值在数组所有元素之后的情况 [left, right] 因为是右闭区间,所以 return right + 1
return right + 1; return right + 1;
} }
}; };
``` ```
* 时间复杂度:$O(\log n)$ * 时间复杂度O(log n)
* 时间复杂度:$O(1)$ * 时间复杂度O(1)
效率如下: 效率如下:
![35_搜索插入位置2](https://img-blog.csdnimg.cn/2020121623272877.png) ![35_搜索插入位置2](https://img-blog.csdnimg.cn/2020121623272877.png)
@ -178,7 +178,7 @@ public:
// 目标值在数组所有元素之前 [0,0) // 目标值在数组所有元素之前 [0,0)
// 目标值等于数组中某一个元素 return middle // 目标值等于数组中某一个元素 return middle
// 目标值插入数组中的位置 [left, right) return right 即可 // 目标值插入数组中的位置 [left, right) return right 即可
// 目标值在数组所有元素之后的情况 [left, right)return right 即可 // 目标值在数组所有元素之后的情况 [left, right)因为是右开区间,所以 return right
return right; return right;
} }
}; };

View File

@ -36,6 +36,8 @@
## 思路 ## 思路
为了易于大家理解,我还录制了视频,可以看这里:[手把手带你撕出正确的二分法](https://www.bilibili.com/video/BV1fA4y1o715)
**这道题目的前提是数组为有序数组**,同时题目还强调**数组中无重复元素**,因为一旦有重复元素,使用二分查找法返回的元素下标可能不是唯一的,这些都是使用二分法的前提条件,当大家看到题目描述满足如上条件的时候,可要想一想是不是可以用二分法了。 **这道题目的前提是数组为有序数组**,同时题目还强调**数组中无重复元素**,因为一旦有重复元素,使用二分查找法返回的元素下标可能不是唯一的,这些都是使用二分法的前提条件,当大家看到题目描述满足如上条件的时候,可要想一想是不是可以用二分法了。
二分查找涉及的很多的边界条件,逻辑比较简单,但就是写不好。例如到底是 `while(left < right)` 还是 `while(left <= right)`,到底是`right = middle`呢,还是要`right = middle - 1`呢? 二分查找涉及的很多的边界条件,逻辑比较简单,但就是写不好。例如到底是 `while(left < right)` 还是 `while(left <= right)`,到底是`right = middle`呢,还是要`right = middle - 1`呢?

View File

@ -23,6 +23,8 @@
# 思路 # 思路
为了易于大家理解,我还特意录制了视频,[本题视频讲解](https://www.bilibili.com/video/BV1QB4y1D7ep)
## 暴力排序 ## 暴力排序
最直观的想法,莫过于:每个数平方之后,排个序,美滋滋,代码如下: 最直观的想法,莫过于:每个数平方之后,排个序,美滋滋,代码如下:

312
problems/qita/gitserver.md Normal file
View File

@ -0,0 +1,312 @@
# 一文手把手教你搭建Git私服
## 为什么要搭建Git私服
很多同学都问文章文档资料怎么备份啊自己电脑和公司电脑怎么随时同步资料啊等等这里呢我写一个搭建自己的git私服的详细教程
为什么要搭建一个Git私服呢而不是用Github免费的私有仓库有以下几点
* Github 私有仓库真的慢文件一旦多了或者有图片文件git pull 的时候半天拉不下来
* 自己的文档难免有自己个人信息放在github心里也是担心的
* 想建几个库就建几个,想几个人合作开发都可以,不香么?
**网上可以搜到很多git搭建但是说的模棱两可**而且有的直接是在本地搭建git服务既然是备份搭建在本地哪有备份的意义一定要有一个远端服务器 而且自己的电脑和公司的电脑还是同步自己的文章,文档和资料等等。
适合人群: 想通过git私服来备份自己的文章Markdown并做版本管理的同学
最后,写好每篇 Chat 是对我的责任,也是对你的尊重。谢谢大家~
正文如下:
-----------------------------
## 如何找到可以外网访问服务器
有的同学问了,自己的电脑就不能作为服务器么?
这里要说一下安装家庭带宽运营商默认是不会给我们独立分配公网IP的
一般情况下是一片区域公用一个公网IP池所以外网是不能访问到在家里我们使用的电脑的
除非我们自己去做映射这其实非常麻烦而且公网IP池 是不断变化的
辛辛苦苦做了映射运营商给IP一换我们的努力就白扯了
那我们如何才能找到一个外网可以访问的服务器呢,此时云计算拯救了我们。
推荐大家选一家云厂商(阿里云,腾讯云,百度云都可以)在上面上买一台云服务器
* [阿里云活动期间服务器购买](https://www.aliyun.com/minisite/goods?taskCode=shareNew2205&recordId=3641992&userCode=roof0wob)
* [腾讯云活动期间服务器购买](https://curl.qcloud.com/EiaMXllu)
云厂商经常做活动,如果从来没有买过云服务器的账号更便宜,低配一年一百块左右的样子,强烈推荐一起买个三年。
买云服务器的时候推荐直接安装centos系统。
这里要说一下,有了自己的云服务器之后 不仅仅可以用来做git私服
**同时还可以做网站,做程序后台,跑程序,做测试**(这样我们自己的电脑就不会因为自己各种搭建环境下载各种包而搞的的烂糟糟),等等等。
有自己云服务器和一个公网IP真的是一件非常非常幸福的事情能体验到自己的服务随时可以部署上去提供给所有人使用的喜悦。
外网可以访问的服务器解决了接下来就要部署git服务了
本文将采用centos系统来部署git私服
## 服务器端安装Git
切换至root账户
```
su root
```
看一下服务器有没有安装git如果出现下面信息就说明是有git的
```
[root@instance-5fcyjde7 ~]# git
usage: git [--version] [--help] [-c name=value]
[--exec-path[=<path>]] [--html-path] [--man-path] [--info-path]
[-p|--paginate|--no-pager] [--no-replace-objects] [--bare]
[--git-dir=<path>] [--work-tree=<path>] [--namespace=<name>]
<command> [<args>]
The most commonly used git commands are:
add Add file contents to the index
bisect Find by binary search the change that introduced a bug
branch List, create, or delete branches
checkout Checkout a branch or paths to the working tree
clone Clone a repository into a new directory
commit Record changes to the repository
diff Show changes between commits, commit and working tree, etc
fetch Download objects and refs from another repository
grep Print lines matching a pattern
init Create an empty Git repository or reinitialize an existing one
log Show commit logs
merge Join two or more development histories together
mv Move or rename a file, a directory, or a symlink
pull Fetch from and merge with another repository or a local branch
push Update remote refs along with associated objects
rebase Forward-port local commits to the updated upstream head
reset Reset current HEAD to the specified state
rm Remove files from the working tree and from the index
show Show various types of objects
status Show the working tree status
tag Create, list, delete or verify a tag object signed with GPG
'git help -a' and 'git help -g' lists available subcommands and some
concept guides. See 'git help <command>' or 'git help <concept>'
to read about a specific subcommand or concept.
```
如果没有git就安装一下yum安装的版本默认是 `1.8.3.1`
```
yum install git
```
安装成功之后,看一下自己安装的版本
```
git --version
```
## 服务器端设置Git账户
创建一个git的linux账户这个账户只做git私服的操作也是为了安全起见
如果不新创建一个linux账户在自己的常用的linux账户下创建的话哪天手抖 来一个`rm -rf *` 操作 数据可全没了
**这里linux git账户的密码设置的尽量复杂一些我这里为了演示就设置成为'gitpassword'**
```
adduser git
passwd gitpassword
```
然后就要切换成git账户进行后面的操作了
```
[root@instance-5fcyjde7 ~]# su - git
```
看一下自己所在的目录是不是在git目录下面
```
[git@instance-5fcyjde7 ~]$ pwd
/home/git
```
## 服务器端密钥管理
创建`.ssh` 目录,如果`.ssh` 已经存在了,可以忽略这一项
为啥用配置ssh公钥呢同学们记不记得我急使用github上传上传代码的时候也要把自己的公钥配置上github上
这也是方面每次操作git仓库的时候不用再去输入密码
```
cd ~/
mkdir .ssh
```
进入.ssh 文件下,创建一个 `authorized_keys` 文件,这个文件就是后面就是要放我们客户端的公钥
```
cd ~/.ssh
touch authorized_keys
```
别忘了`authorized_keys`给设置权限,很多同学发现自己不能免密登陆,都是因为忘记了给`authorized_keys` 设置权限
```
chmod 700 /home/git/.ssh
chmod 600 /home/git/.ssh/authorized_keys
```
接下来我们要把客户端的公钥放在git服务器上我们在回到客户端创建一个公钥
在我们自己的电脑上,有公钥和私钥 两个文件分别是:`id_rsa``id_rsa.pub`
如果是`windows`系统公钥私钥的目录在`C:\Users\用户名\.ssh`
如果是mac 或者 linux 公钥和私钥的目录这里 `cd ~/.ssh/` 如果发现自己的电脑上没有公钥私钥,那就自己创建一个
创建密钥的命令
```
ssh-keygen -t rsa
```
创建密钥的过程中,一路点击回车就可以了。不需要填任何东西
把公钥拷贝到git服务器上将我们刚刚生成的`id_rsa.pub`拷贝到git服务器的`/home/git/.ssh/`目录
在git服务器上将公钥添加到`authorized_keys` 文件中
```
cd /home/git/.ssh/
cat id_rsa.pub >> authorized_keys
```
如何看我们配置的密钥是否成功呢, 在客户点直接登录git服务器看看是否是免密登陆
```
ssh git@git服务器ip
```
例如:
```
ssh git@127.0.0.1
```
如果可以免密登录,那就说明服务器端密钥配置成功了
## 服务器端部署Git 仓库
我们在登陆到git 服务器端,切换为成 git账户
如果是root账户切换成git账户
```
su - git
```
如果是其他账户切换为git账户
```
sudo su - git
```
进入git目录下
```
cd ~/git
```
创建我们的第一个Git私服的仓库我们叫它为world仓库
那么首先创建一个文件夹名为: world.git ,然后进入这个目录
有同学问,为什么文件夹名字后面要放`.git` 其实不这样命名也是可以的
但是细心的同学可能注意到我们平时在github上 `git clone` 其他人的仓库的时候,仓库名字后面,都是加上`.git`
例如下面这个例子其实就是github对仓库名称的一个命名规则所以我们也遵守github的命名规则。
```
git clone https://github.com/youngyangyang04/NoSQLAttack.git
```
所以我们的操作是
```
[git@localhost git]# mkdir world.git
[git@localhost git]# cd world.git
```
初始化我们的`world`仓库
```
git init --bare
```
**如果我们想创建多个仓库就在这里创建多个文件夹并初始化就可以了和world仓库的操作过程是一样一样的**
现在我们服务端的git仓库就部署完了接下来就看看客户端如何使用这个仓库呢
## 客户端连接远程仓库
我们在自己的电脑上创建一个文件夹 也叫做`world`
其实这里命名是随意的但是我们为了和git服务端的仓库名称保持同步。 这样更直观我们操作的是哪一个仓库。
```
mkdir world
cd world
```
进入world文件并初始化操作
```
cd world
git init
```
在world目录上创建一个测试文件并且将其添加到git版本管理中
```
touch test
git add test
git commit -m "add test file"
```
将次仓库和远端仓库同步
```
git remote add origin git@git服务器端的ip:world.git
git push -u origin master
```
此时这个test测试文件就已经提交到我们的git远端私服上了
## Git私服安全问题
这里有两点安全问题
### linux git的密码不要泄露出去
否则,别人可以通过 ssh git@git服务器IP 来登陆到你的git私服服务器上
当然了,这里同学们如果买的是云厂商的云服务器的话
如果有人恶意想通过 尝试不同密码链接的方式来链接你的服务器,重试三次以上
这个客户端的IP就会被封掉同时邮件通知我们可以IP来自哪里
所以大可放心 密码只要我们不泄露出去基本上不会有人同时不断尝试密码的方式来登上我们的git私服服务器
### 私钥文件`id_rsa` 不要给别人
如果有人得到了这个私钥就可以免密码登陆我们的git私服上了我相信大家也不至于把自己的私钥主动给别人吧
## 总结
这里就是整个git私服搭建的全过程安全问题我也给大家列举了出来接下来好好享受自己的Git私服吧
**enjoy!**

126
problems/qita/server.md Normal file
View File

@ -0,0 +1,126 @@
# 一台服务器有什么用!
但在组织这场活动的时候,了解到大家都有一个共同的问题: **这个服务器究竟有啥用??**
这真是一个好问题,而且我一句两句还说不清楚,所以就专门发文来讲一讲。
同时我还录制的一期视频,哈哈我的视频号,大家可以关注一波。
一说到服务器,可能很多人都说搞分布式,做计算,搞爬虫,做程序后台服务,多人合作等等。
其实这些普通人都用不上,我来说一说大家能用上的吧。
## 搭建git私服
大家平时工作的时候一定有一个自己的工作文件夹,学生的话就是自己的课件,考试,准备面试的资料等等。
已经工作的录友会有一个文件夹放着自己重要的文档Markdown图片简历等等。
这么重要的文件夹,而且我们每天都要更新,也担心哪天电脑丢了,或者坏了,突然这些都不见了。
所以我们想备份嘛。
还有就是我们经常个人电脑和工作电脑要同步一些私人资料,而不是用微信传来传去。
这些都是git私服的使用场景而且很好用。
大家也知道 githubgitee也可以搞私人仓库 用来备份同步文件但自己的文档可能放着很多重要的信息包括自己的各种密码密钥之类的放到上面未必安全。你就不怕哪些重大bug把你的信息都泄漏了么[机智]
更关键的是github 和 gitee都限速的。毕竟人家的功能定位并不是网盘。
项目里有大文件几百M以上例如pdfppt等等 其上传和下载速度会让你窒息。
**后面我会发文专门来讲一讲如何大家git私服**
## 搞一个文件存储
这个可以用来生成文件的下载链接,也可以把本地文件传到服务器上。
相当于自己做一个对象存储,其实云厂商也有对象存储的产品。
不过我们自己也可以做一个,不够很多很同学应该都不知道对象存储怎么用吧,其实我们用服务器可以自己做一个类似的公司。
我现在就用自己用go写的一个工具部署在服务器上。 用来和服务器传文件,或者生成一些文件的临时下载链接。
这些都是直接命令行操作的,
操作方式这样,我把命令包 包装成一个shell命令想传那个文件直接 uploadtomyserver然后就返回可以下载的链接这个文件也同时传到了我的服务器上。
![](https://code-thinking-1253855093.file.myqcloud.com/pics/20211126165643.png)
我也把我的项目代码放在了github上
https://github.com/youngyangyang04/fileHttpServer
感兴趣的录友可以去学习一波顺便给个star 哈哈
## 网站
做网站,例如 大家知道用html 写几行代码,就可以生成一个网页,但怎么给别人展示呢?
大家如果用自己的电脑做服务器,只能同一个路由器下的设备可以访问你的网站,可能这个设备出了这个屋子 都访问不了你的网站了。
因为你的IP不是公网IP。
如果有了一台云服务器都是配公网IP你的网站就可以让任何人访问了。
或者说 你提供的一个服务就可以让任何人使用。
例如第二个例子中,我们可以自己开发一个文件存储,这个服务,我只把把命令行给其他人,其他人都可以使用我的服务来生成链接,当然他们的文件也都传到了我的服务器上。
再说一个使用场景。
我之前在组织免费里服务器的活动的时候阿里云给我一个excel让面就是从我这里买服务器录友的名单我直接把这个名单甩到群里让大家自己检查出现在名单里就可以找我返现这样做是不是也可以。
这么做有几个很大的问题:
* 大家都要去下载excel做对比会有人改excel的内容然后就说是从你这里买的我不可能挨个去比较excel有没有改动
* excel有其他人的个人信息这是不能暴漏的。
* 如果每个人自己用excel查询私信我返现一个将近两千人找我返现我微信根本处理不过来这就变成体力活了。
那应该怎么做呢,
我就简单写一个查询的页面后端逻辑就是读一个execel表格大家在查询页面输入自己的阿里云ID如果在excel里页面就会返回返现群的二维码大家就可以自主扫码加群了。
这样,我最后就直接在返现群里 发等额红包就好了,是不是极大降低人力成本了
当然我是把 17个返现群的二维码都生成好了按照一定的规则展现给查询通过的录友。
就是这样一个非常普通的查询页面。
![](https://code-thinking-1253855093.file.myqcloud.com/pics/20211126160200.png)
查询通过之后,就会展现返现群二维码。
![](https://code-thinking-1253855093.file.myqcloud.com/pics/20211127160558.png)
但要部署在服务器上因为没有公网IP别人用不了你的服务。
## 学习linux
学习linux其实在自己的电脑上搞一台虚拟机或者安装双系统也可以学习不过这很考验你的电脑性能如何了。
如果你有一个服务器,那就是独立的一台电脑,你怎么霍霍就怎么霍霍,而且一年都不用关机的,可以一直跑你的任务,和你本地电脑也完全隔离。
更方便的是你目前系统假如是centos想做一个实验需要在unbantu上如果是云服务器更换系统就是在 后台点一下,一键重装,云厂商基本都是支持所有系统一件安装的。
我们平时自己玩linux经常是配各种环境然后这个linux就被自己玩坏了一般都是毫无节制使用root权限导致的总之就是环境配不起来了基本就要重装了。
那云服务器重装系统可太方便了。
还有就是加入你好不容易配好的环境,如果以后把这个环境玩坏了,你先回退这之前配好的环境而不是重装系统在重新配一遍吧。
那么可以用云服务器的镜像保存功能,就是你配好环境的那一刻就可以打一个镜像包,以后如果环境坏了,直接回退到上次镜像包的状态,这是不是就很香了。
## 总结
其实云服务器还有很多其他用处,不过我就说一说大家普遍能用的上的。
* [阿里云活动期间服务器购买](https://www.aliyun.com/minisite/goods?taskCode=shareNew2205&recordId=3641992&userCode=roof0wob)
* [腾讯云活动期间服务器购买](https://curl.qcloud.com/EiaMXllu)