2022.02.04 Day1
前言
为日后的算法面试做准备,自己也很喜欢算法这个东西,每天3~5道题。
刷题
1.leetcode 209 长度最下的子数组
题目
长度最下的子数组
大致的意思是从数组中找到长度最小的数组,并且数组内的和是大于等于给定的数target的
思路
最基本的思路当然是双重遍历,时间复杂度是O(N2),但是本题的数据大小为105,所以这是肯定过不掉的,所以我们需要优化。
我们可以发现的是,对于满足条件的某个区间,区间左右端点分别i与j,其中i表示最接近j的那个数的下标,当j向右移动的时候,i也会向右移动或者原地不动。所以我们可以用双指针来优化这个到O(N)。
代码
class Solution {
public:
int minSubArrayLen(int target, vector<int>& nums) {
int res = INT_MAX;
//每次找的是能处于最左边的数
for(int i = 0, j = 0,sum_ = 0; j < nums.size();++j){
sum_ += nums[j];
while(sum_ - nums[i] >= target) sum_ -= nums[i++];
if(sum_ >= target)res = min(res, j - i + 1);
}
/*对于每个nums[j]找到的nums[i]是离nums[j]最近的那个满足sum_ >= target的数
每次这样维护是最小的
*/
if(res == INT_MAX) res = 0;
return res;
}
};
2.leetcode 208 实现Trie(前缀树)
题目
思路
就是Trie的模板题,我习惯用数组来模拟Trie树,所以打个板子题就好了,要用个check数组来维护一下最后一个数即可,大概把数据范围定在在8e4以上就可以过了。不过实测发现8e4跟1e5的运行速度不一样,后者会快个20多ms,可能是因为在解析8e4的时候会慢一点?
然后有个细节是,用bool类型的check数组,因为bool的大小是1个字节,会相对于int小一点,在内存上会更加占优。
代码
const int N = 1e5;
int son[N][26], idx = 0;
bool check[N];
class Trie {
public:
Trie() {
memset(son, 0 ,sizeof(son));
memset(check, 0 ,sizeof(check));
}
void insert(string word) {
int pos = 0;
for(int i = 0; word[i]; ++ i){
int temp = word[i] - 'a';
if(!son[pos][temp]) son[pos][temp] = ++idx;
pos = son[pos][temp];
//check[pos] = 1;
}
check[pos] = 1;
}
bool search(string word) {
int pos = 0;
for(int i = 0; word[i]; ++ i){
int temp = word[i] - 'a';
if(!son[pos][temp]) return false;
pos = son[pos][temp];
}
if(check[pos]) return true;
else return false;
}
bool startsWith(string prefix) {
int pos = 0,temp;
for(int i = 0; prefix[i]; ++ i){
temp = prefix[i] - 'a';
if(!son[pos][temp]) return false;
pos = son[pos][temp];
}
return true;
}
};
/**
* Your Trie object will be instantiated and called as such:
* Trie* obj = new Trie();
* obj->insert(word);
* bool param_2 = obj->search(word);
* bool param_3 = obj->startsWith(prefix);
*/
3.leetcode 201 数字范围按位与
题目
思路
对于left 和 right 我们会发现二进制表示中的两个数从左到右第一个不相等的数的后面按位与起来的后都是0.
也就是left可能是XXX0YYY,right可能是XXX1ZZZ,这是由于left小于right,我们还能发现XXX1000与XXX0111肯定都在left与right的范围内,所以从第一个不相同的位向后与都是0.即答案是XXX0000。
代码
class Solution {
public:
int rangeBitwiseAnd(int left, int right) {
int res = 0;
for(int i = 30; i >= 0; --i){
if((left >> i & 1) != (right >> i & 1)) {//lowbit操作
res = res << i + 1;
break;
}
else{
res = (res << 1) + (left >> i & 1);
}
}
return res;
}
};
注意点是lowbit操作一定要与上1,否则将一个数向左或者向右移动i位的话,得到的结果只会是移位后的结果。
2022.02.04 Day1的更多相关文章
- ROS的安装-> rosdep init /update报错2022.02.24实测有效
ROS的安装-> rosdep init /update报错2022.02.24实测有效 一. 解决rosdep_init问题 正常执行sudo rosdep init会报错,如下: ERR ...
- 2022.02.27 CF811E Vladik and Entertaining Flags
2022.02.27 CF811E Vladik and Entertaining Flags https://www.luogu.com.cn/problem/CF811E Step 1 题意 在一 ...
- 2022.02.27 CF811E Vladik and Entertaining Flags(线段树+并查集)
2022.02.27 CF811E Vladik and Entertaining Flags(线段树+并查集) https://www.luogu.com.cn/problem/CF811E Ste ...
- 2022.02.21 UB
2022.02.21 UB 参考资料: https://zhuanlan.zhihu.com/p/141467895 https://blog.csdn.net/ghscarecrow/article ...
- 2022.02.21 SA
2022.02.21 SA 当我年少轻狂时,我曾拥有自由,但我并不明白它的意义.我曾拥有时间,但我没有意识到它的珍贵.我曾拥有爱,但我从未用心去体会.数十年的时间考验后,我终于理解了三者的真谛. 我已 ...
- 2022.02.20 SA
2022.02.20 SA 如果我还能看见明天黎明,如果我还能再爬起来,我仍会走我的路,哪怕这条路已经荒废许久,也许我们无法拥有感情,我们甚至无法像个正常人一样接受太阳的洗礼,但是我依然会执行我的条约 ...
- [2017.02.04] C++学习记录(1)
编编程语言的目的是帮助程序员以代码的形式表述ideas.编程语言一方面为程序员提供一组关于可以做什么的抽象,另一方面为程序员提供可以被机器执行的轮子.C++编程语言,支持4种编程范式:过程式(Proc ...
- C语言学习记录_2019.02.04
逻辑性变量的定义符:bool,在C语言中只有true和false: 定义方式:bool t = true; 逻辑运算符: !:逻辑非 &&:逻辑与 ||:逻辑或 表达区间的错误形式:4 ...
- 2022.02.05 DAY2
前言 今天陪老姐送对象去安庆了,上午还去了西风禅寺求了个签,第一次拿到中评签,看来今年还需要继续努力哈哈哈.一直到晚上才有时间去做点题目,今天依旧是leetcode. 题目 leetcode 1 两数 ...
随机推荐
- Abelian Period
Abelian Period Accepts: 288 Submissions: 984 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 26 ...
- MySQL中的where和having
group by 在select 语句中可以使用group by 子句将行划分成较小的组,然后,使用聚组函数返回每一个组的汇总信息,另外,可以使用having子句限制返回的结果集.group by 子 ...
- DFT, DHT, DCT, DST
目录 基本 酉变换 others Fourier-related Transforms DFT DHT DCT 与DFT的联系 DST 与DFT的联系 Gonzalez R. C. and Woods ...
- 基于Spring MVC + Spring + MyBatis的【学生管理管理系统】
资源下载:https://download.csdn.net/download/weixin_44893902/45602690 练习点设计:模糊查询.删除.新增 一.语言和环境 实现语言:JAVA语 ...
- Microsoft HoloLens 开发(1): 搭建 HoloLens 开发环境
1.硬件配置 64位 Windows 10 专业版, 企业版, or 教育版 (注: 家庭版不支持 Hyper-V 或者 HoloLens emulator) 64位 CPU 4核CPU (或者大于4 ...
- Django_视图中的request对象详解(八)
本文参考:http://www.cnblogs.com/MnCu8261/p/5871085.html Request 我们知道当URLconf文件匹配到用户输入的路径后,会调用对应的view函数,并 ...
- Centos7 mysqldump定时任务,对mysql定时备份数据
vi mysqldump_bak.sh #!/bin/bash PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/ ...
- [vscode] os.getcwd(),调试和命令行运行的结果不一致
问题描述: 调试和命令行运行的时候工作目录不一致 这会导致一个问题,我想从上级目录导入模块的话,F5调试就会找不到模块,而命令行则没问题 那么我该如何调试呢? 目录结构: top └ folder_ ...
- NIO【同步非阻塞io模型】关于 文件io 的总结
1.前言 这一篇随笔是写 NIO 关于文件输入输出的总结 /* 总结: 1.io操作包括 socket io ,file io ; 2.在nio模型,file io使用fileChannel 管道 , ...
- 关于APP设计规范和一些图层命名
首先,本人大学计算机专业出身,学过编程,工作的时候做过 产品经理,设计师,前端工程师,对工作的流程都有一些见解. 现在主攻前端工程师,做Web APP.今天收到设计师的设计稿,一看图层分类,这让我感觉 ...