day1-牛客67道剑指offer-JZ4 JZ6 JZ7 JZ9 JZ11 JZ69 JZ70 替换空格 斐波那契数列及其变形 左移/右移运算符

文章目录

  • 1. JZ4 二维数组中的查找
    • 暴力法
    • 右上角往左下角逼近
    • 二分查找-左闭右开区间
  • 2. 替换空格
  • 3. JZ6 从尾到头打印链表
  • 4. JZ7 重建二叉树
    • 思路1
    • 哈希加速
  • 5. JZ9 用两个栈实现队列
  • 6. JZ11 旋转数组的最小数字
    • 常规遍历
    • 二分法
  • 7. 斐波那契数列
    • 动态规划
    • 递归
  • 8. JZ69 跳台阶
    • 动态规划
    • 递归
  • 9. JZ71 跳台阶扩展问题
    • 动态规划-看题解
    • 动态规划-优化空间
    • 数学规律-优化时间空间-左移运算
  • 10. JZ70 矩形覆盖
    • 动态规划 数组写法
    • 动态规划 三个变量
  • 补充内容:左移运算符与右移运算符

1. JZ4 二维数组中的查找

在这里插入图片描述

暴力法

两层for循环,自测可通过,超时,时间复杂度m*n

右上角往左下角逼近

利用递增,右上角为分割点

    bool Find(int target, vector<vector<int> >& array) {       //右上角逐渐逼近左下角 递增if(array.empty() || array[0].empty()) return false;int row = array[0].size();int col = array.size();int w = row - 1, h = 0;while(w >= 0 && h < col){if(array[h][w] > target) w--;//array[h][w]表示右上角 target在左边 往左走else if(array[h][w] < target) h++;//target在下面 往下走else return true;}return false;}

二分查找-左闭右开区间

也可以是左闭右闭区间实现

    bool Find(int target, vector<vector<int> >& array) {//二分查找if(array.empty() || array[0].empty()) return false;//遍历每一行 二分for(int i=0; i<array.size(); i++){if(binaryfind(array[i], target)) return true;}return false;}bool binaryfind(vector<int>nums, int target){//左闭右开区间int start = 0, end = nums.size();int mid = 0;for(int i=0; i<nums.size(); i++){mid = start + (end - start) / 2;if(target < nums[i]) end = mid;else if(target > nums[i]) start = mid + 1;else return true;}return false;}

2. 替换空格

题目:请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy

统计空格长度,倒序遍历替换
第一次写的时候用的是for(int i=length; i>=0 && i<newlen; i--)条件
这次写的时候用的是for(int i=length; i>=0 && newlen!=i; i--)条件

class Solution {
public:void replaceSpace(char *str,int length) {int spacelen = 0;for(int i=0; i<length; i++){if(str[i] == ' ') spacelen++;}int newlen = length + 2*spacelen;//替换 如果newlen=i 说明此时前面已经都没有空格了,可以节约一部分时间,而不是一直赋值下去for(int i=length; i>=0 && newlen!=i; i--)//for(int i=length; i>=0 && i<newlen; i--){if(str[i] == ' '){str[newlen--] = '0';str[newlen--] = '2';str[newlen--] = '%';}else str[newlen--] = str[i];}int spaceCount = 0;}
};

3. JZ6 从尾到头打印链表

题目:输入一个链表,按链表从尾到头的顺序返回一个ArrayList

正序保存,然后reverse返回。或者返回逆序

/**
*  struct ListNode {
*        int val;
*        struct ListNode *next;
*        ListNode(int x) :
*              val(x), next(NULL) {
*        }
*  };
*/
#include <algorithm>
class Solution {
public:vector<int> printListFromTailToHead(ListNode* head) {if(head == NULL) return vector<int>();//正序保存+reversevector<int> result;ListNode* cur = head;while(cur){result.push_back(cur->val);cur = cur->next;}/*reverse(result.begin(), result.end());return result;*/return vector<int>(result.rbegin(),result.rend());}
};

4. JZ7 重建二叉树

题目:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。

力扣上有一道题是根据中序和后序遍历结果重建树,106. 从中序与后序遍历序列构造二叉树,这道题是根据中序和前序遍历结果重建树。

思路1

根节点分割中序遍历结果,左子树节点数分割前序遍历结果

/*** struct TreeNode {*	int val;*	struct TreeNode *left;*	struct TreeNode *right;*	TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* };*/
#include <iterator>
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param preOrder int整型vector * @param vinOrder int整型vector * @return TreeNode类*/TreeNode* reConstructBinaryTree(vector<int>& preOrder, vector<int>& vinOrder) {if (preOrder.size() == 0 || vinOrder.size() == 0) {return NULL;}//distance两个迭代器之间元素个数 find查找两个迭代器之间是否有元素preOrder[0]int rootindex = distance(vinOrder.begin(), find(vinOrder.begin(), vinOrder.end(), preOrder[0]));//前序遍历 左闭右开区间 左子树 右子树分割 利用节点个数 注意去掉根节点vector<int> left_pre(preOrder.begin() + 1, preOrder.begin() + 1 + rootindex);vector<int> right_pre(preOrder.begin() + 1 + rootindex, preOrder.end());//中序遍历 左闭右开区间 左子树 右子树分割 利用根节点vector<int> left_vin(vinOrder.begin(), vinOrder.begin() + rootindex);vector<int> right_vin(vinOrder.begin() + rootindex + 1, vinOrder.end());//递归构造TreeNode* head = new TreeNode(preOrder[0]);head->left = reConstructBinaryTree(left_pre, left_vin);head->right = reConstructBinaryTree(right_pre, right_vin);return head;}
};

哈希加速

/*** struct TreeNode {*	int val;*	struct TreeNode *left;*	struct TreeNode *right;*	TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* };*/
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param preOrder int整型vector * @param vinOrder int整型vector * @return TreeNode类*/TreeNode* reConstructBinaryTree(vector<int>& preOrder, vector<int>& vinOrder) {//哈希加速unordered_map<int, int> hashmap;for(int i=0; i<vinOrder.size(); i++){hashmap.insert(make_pair(vinOrder[i], i));}//递归return tralversal(hashmap, preOrder, 0, vinOrder, 0, vinOrder.size()-1);}TreeNode* tralversal(unordered_map<int, int>& hashmap, vector<int>& pre, int start_pre, vector<int>& vin, int start_vin, int end_vin){//可以取等号if(start_pre > pre.size() || start_vin > end_vin) return nullptr;TreeNode* root = new TreeNode(pre[start_pre]);int rootindex = hashmap[pre[start_pre]];//第三个参数是 前序遍历中左子树的 头结点 索引位置 //第五、六参数是索引范围是中序遍历的左子树区间 start_vin~rootindex - 1 左闭右闭root->left = tralversal(hashmap, pre, start_pre+1, vin, start_vin, rootindex - 1);//第三个参数是 前序遍历中右子树的 头结点 索引位置 在前序遍历中是start_pre+1+左子树节点数//第五、六参数是索引范围是中序遍历的右子树区间 rootindex+1~end_vin 左闭右闭root->right = tralversal(hashmap, pre, start_pre+1+rootindex-start_vin, vin, rootindex+1, end_vin);return root;}
};

5. JZ9 用两个栈实现队列

题目描述:完成队列的Push和Pop操作。 队列中的元素为int类型

两个栈实现,一个保存元素,一个辅助

class Solution
{
public:void push(int node) {stack1.push(node);}int pop() {//队列是双头 先入先出;栈是单头 先进后出 所以要倒序一下while(stack1.size() != 1)//保留栈底元素{stack2.push(stack1.top());stack1.pop();}int target = stack1.top();stack1.pop();//剩下的元素再放回去stack1中while (!stack2.empty()) {stack1.push(stack2.top());stack2.pop();}return target;}private:stack<int> stack1;//保存元素stack<int> stack2;//辅助栈
};

6. JZ11 旋转数组的最小数字

题目描述:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。
NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。

常规遍历

class Solution {
public:int minNumberInRotateArray(vector<int>& nums) {if(nums.size() == 0) return 0;//遍历整个数组for(int i=0; i<nums.size(); i++){if(nums[i] > nums[i+1]) return nums[i+1];}return nums[0];}
};

二分法

class Solution {
public:int minNumberInRotateArray(vector<int>& nums) {if(nums.size() == 0) return 0;//二分法 左闭右开 最值在两头int left = 0, right = nums.size()-1;while(left+1 < right){int mid = left + (right - left) / 2;if(nums[mid] < nums[right]) right = mid;//说明右边有序,那就向左边走else if(nums[mid] == nums[right]) right = right-1;else left = mid;}return min(nums[left], nums[right]);}
};

7. 斐波那契数列

题目描述:大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0,第1项是1)。n≤39

动态规划

三个数值保存在一个数组,注意最后返回值是n-1对3取余数

class Solution {
public:int Fibonacci(int n) {if(n == 1 || n == 2) return 1;if(n == 3) return 2;vector<int> F(3);F[0] = 1;F[1] = 1;F[2] = 2;for(int i=3; i<n; i++){F[i % 3] = F[(i-1) % 3] + F[(i-2) % 3];}return F[(n-1) % 3];}
};

递归

class Solution {
public:int Fibonacci(int n) {//递归if(n == 0) return 0;if(n == 1 || n == 2) return 1;return Fibonacci(n-1) + Fibonacci(n-2);}
};

8. JZ69 跳台阶

题目描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。
相当于斐波那契数列

动态规划

动态规划的定义是跳n级台阶有多少种跳法

class Solution {
public:int jumpFloor(int number) {//动态规划if(number == 1) return 1;if(number == 2) return 2; vector<int> dp(3);dp[0] = 1;dp[1] = 2;for(int i=2; i<number; i++){dp[i % 2] = dp[(i-1) % 2] + dp[(i-2) % 2];}return dp[(number-1) % 2];}
};

递归

class Solution {
public:int jumpFloor(int number) {//递归if(number == 1) return 1;if(number == 2) return 2; return jumpFloor(number-1) + jumpFloor(number-2);}
};

9. JZ71 跳台阶扩展问题

题目描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。

动态规划-看题解

时间复杂度: O ( n ) O(n) O(n),其中n为台阶数,一次遍历;空间复杂度: O ( n ) O(n) O(n),辅助数组dp的长度为n

在这里插入图片描述在这里插入图片描述

class Solution {
public:int jumpFloorII(int number) {//动态规划-题解vector<int> dp(number+1);dp[0] = 1;dp[1] = 1;for(int i=2; i<=number; i++) dp[i] = 2 * dp[i-1];return dp[number];}
};

动态规划-优化空间

在上面看了题解写之后,优化了空间,时间复杂度: O ( n ) O(n) O(n);空间复杂度: O ( 1 ) O(1) O(1)

class Solution {
public:int jumpFloorII(int number) {//动态规划-空间优化vector<int> dp(3);dp[0] = 1;dp[1] = 1;for(int i=2; i<=number; i++){dp[i % 2] = 2 * dp[(i-1) % 2];}return dp[number % 2];}
};

数学规律-优化时间空间-左移运算

在这里插入图片描述
在这里插入图片描述
时间复杂度: O ( 1 ) O(1) O(1),一次位运算;空间复杂度: O ( 1 ) O(1) O(1)

通过左移运算求幂次方来优化时间复杂度,也就是说pow(2, number - 1) 等价于 1<<number-11<<number-1就是将1左移number-1位

class Solution {
public:int jumpFloorII(int number) {//数学规律-时间优化if(number <= 1) return 1;//return pow(2, number - 1);//计算2的number-1次方 时间复杂度是n 空间是1return 1<<number-1;//将1左移number-1位 通过左移运算求幂次方 时间/空间复杂度是1}
};

10. JZ70 矩形覆盖

题目描述:我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2n的大矩形,总共有多少种方法?注意:约定 n == 0 时,输出 0
比如n=3时,2
3的矩形块有3种覆盖方法,如下

宽度永远是2,那么题目换个说法就是,用n个边长为1的短线可以变成边长为n的长线,总共有多少种方法?也就是n个1变成n,一共有多少种办法?其实就是斐波那契额数列。

动态规划 数组写法

class Solution {
public:int rectCover(int number) {if(number <= 2) return number;vector<int> dp(3);dp[0] = 0;dp[1] = 1;dp[2] = 2;for(int i=3; i<=number; i++){dp[i % 3] = dp[(i-1) % 3] + dp[(i-2) % 3];}return dp[number % 3];}
};

动态规划 三个变量

class Solution {
public:int rectCover(int number) {if(number <= 2) return number;//动态规划 三个变量int first = 1, second = 2, third = 0;for(int i=3; i<=number; i++){third = first + second;//下一轮计算前要更新first = second;second = third;}return third;}
};

补充内容:左移运算符与右移运算符

  1. <<左移运算符,逻辑移位:expr1 << expr2,表示 expr1 左移 expr2 位,数值上表示 expr1 扩大了 2^expr2 倍;
  2. >>右移运算符,算术移位:expr1>>expr2,表示 expr2 右移 expr2 位,数值上表示 expr1 缩小了 2^expr2 倍;
  3. 左边的数表示被移位的数字,1<<n = 2^n,n<<1 = 2*n。左移就是扩大2的移位数次方,右移就是缩小2的移位数次方

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/79065.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Swintransformer模型的优化

SwinTransformer模型优化 文章目录 SwinTransformer模型优化1.SwinTransformer概述2.性能瓶颈分析3.模型优化3.1.transpose消除3.2.更好的layergroup3.1.1.SliceOp3.1.2.SqueezeOp3.1.3.weight切分 4.优化效果 1.SwinTransformer概述 自从Transformer在NLP任务上取得突破性的进…

UE5 半透明覆层材质

文章目录 前言介绍示例1示例2示例3 前言 本文采用虚幻5.2.1版本演示&#xff0c;介绍半透明覆层材质&#xff08;覆层材质&#xff09;。 介绍 半透明覆层材质是 UE5.1 版本 更新的功能&#xff0c;使用半透明覆层材质&#xff0c;可以轻松的给物体表面附着一层材质。 在UE5…

[IDEA]使用idea比较两个jar包的差异

除了一些小工具外&#xff0c;idea自带了jar包比较的功能。 把需要比对的jar包放到任意目录下&#xff0c;然后选中两个需要比较的jar包&#xff0c;右键&#xff0c;选择Compare Archives&#xff0c;然后就可以比较了。 这次疏忽了&#xff0c;每次打包前需要commit界面看一下…

Unity 编辑器选择器工具类Selection 常用函数和用法

Unity 编辑器选择器工具类Selection 常用函数和用法 点击封面跳转下载页面 简介 在Unity中&#xff0c;Selection类是一个非常有用的工具类&#xff0c;它提供了许多函数和属性&#xff0c;用于操作和管理编辑器中的选择对象。本文将介绍Selection类的常用函数和用法&#xff…

untiy 连接两个UI或一段固定一段跟随鼠标移动的线段

注意&#xff0c;仅适用于UI&#xff0c;且Canvas必须是Camera模式&#xff0c;不能用在3D物体上&#xff0c;3D物体请使用LineRenender 先创建一个图片&#xff0c;将锚点固定在左边 然后在脚本中添加如下内容 public RectTransform startObj;//起点物体public RectTransfor…

Teams Room视频会议室方案

需求背景&#xff1a; 适合在40平米的会议室参加Teams视频会议&#xff0c;会议桌周围可以坐20人&#xff0c;要求&#xff1a; 1&#xff0c;操作简单&#xff0c;一键入会Teams Room&#xff1b; 2&#xff0c;任何人带上自己的笔记本电脑&#xff0c;可以分享电脑画面&#…

枫叶时代:打造中国特色的传统文化IP

近年来&#xff0c;取材于传统文化的影视作品在文化产业市场受到前所未有的关注。作为一种兼具辨识度、影响力和流量变现能力的文化符号&#xff0c;影视IP既是文化产业的一个重要环节&#xff0c;也是国家文化软实力的直接体现。优秀的影视IP可以超越文字、语言、民族的障碍&a…

yolo-v5学习(使用yolo-v5进行安全帽检测错误记录)

常见错误 跑YOLOv5遇到的问题_runtimeerror: a view of a leaf variable that requi_Pysonmi的博客-CSDN博客 python train.py --img 640 --batch 16 --epochs 10 --data ./data/custom_data.yaml --cfg ./models/custom_yolov5.yaml --weights ./weights/yolov5s.pt 1、梯度…

ubuntu git操作记录设置ssh key

用到的命令&#xff1a; 安装git sudo apt-get install git配置git用户和邮箱 git config --global user.name “用户名” git config --global user.email “邮箱地址”安装ssh sudo apt-get install ssh然后查看安装状态&#xff1a; ps -e | grep sshd4. 查看有无ssh k…

02_kafka_基本概念_基础架构

文章目录 常见的消息队列工作模式基本概念kafka 特性Kafka 基本架构topic 分区的 目的/ 好处 日志存储形式消费者&#xff0c;消费方式 逻辑消费组 高性能写入&#xff1a; 顺序写 mmap读取&#xff1a;零拷贝DMA 使用场景 常见的消息队列工作模式 至多一次&#xff1a;消息被…

yolov5代码解读之​detect.py文件【超详细的好吗!点进来看阿很用心的!】

yolov5的代码一直在更新&#xff0c;所以你们代码有些部分可能不太一样&#xff0c;但大差不差。 先给大家看一下项目结构&#xff1a;&#xff08;最好有这个项目&#xff0c;且跑通过&#xff09; detect.py文件&#xff1a;它可以预测视频、图片文件夹、网络流等等。 如何…

UE4 Cesium for unreal 离线加载应用全流程

参考配置&#xff1a;Win10、请保证是在局域网环境下配置 配置IP 右键选择&#xff1a;打开“网络和Internet” 设置 选择更改适配器选项 请保证以太网是处于启用状态并连接线缆&#xff0c;点击右键选择属性 双击选择Internet协议版本4&#xff08;TCP/IPv4&#xff09; 将IP地…

Mir 2.14 正式发布,Ubuntu 使用的 Linux 显示服务器

导读Canonical 公司最近发布了 Mir 2.14&#xff0c;这是该项目的最新版本。 Mir 2.14 在 Wayland 方面通过 ext-session-lock-v1 协议增加了对屏幕锁定器 (screen lockers) 的支持&#xff0c;并最终支持 Wayland 拖放。此外还整合了渲染平台的实现&#xff0c;放弃了之前在 R…

【UE】AI导航,多个导航物体无法走到同一终点问题

如不需要开启导航物体的碰撞&#xff0c;则需要关闭Use RVOAvoidance 不然会导致多个导航物体无法到达同一个目标点&#xff0c;都在附近晃。无法结束寻路。 ue小白&#xff0c;判定导航终点的半径&#xff0c;没有找到。如果有大佬知道怎么设置请在评论区指出&#xff0c;谢…

【开源项目--稻草】Day04

【开源项目--稻草】Day04 1. 续 VUE1.1 完善VUEAJAX完成注册功能 Spring验证框架什么是Spring验证框架使用Spring-Validation 稻草问答-学生首页显示首页制作首页的流程开发标签列表标签列表显示原理 从业务逻辑层开始编写控制层代码开发问题列表开发业务逻辑层开发页面和JS代码…

docker search 镜像报错: connect: no route to host (桥接模式配置静态IP)

如下 原因 可能有多种&#xff1a; ① 没有开放防火墙端口 ② ip地址配置有误 解决 我是因为虚拟机采用了桥接模式&#xff0c;配置静态ip地址有问题。 先确认虚拟机采用的是 桥接模式&#xff0c;然后启动虚拟机。 1、打开命令行&#xff0c;输入下面指令&#xff0c;打开…

远程访问桌面软件 OpenText Exceed TurboX(ETX)如何提高企业生产力

远程访问桌面软件 OpenText Exceed TurboX&#xff08;ETX&#xff09;如何提高企业生产力 几乎所有规模和行业的企业&#xff0c;员工的工作方式、时间和地点方面发生重大变化&#xff0c;这主要得益于新技术和全球商业与协作。业务领导者正在推动其 IT 部门提出解决方案&…

算法基础简介

目录 1、递归 2、二分查找 3、排序算法 分类 3.1、冒泡排序 3.2、选择排序 3.3、插入排序 3.4、希尔排序(高级插入排序) 3.5、归并排序 3.6、快速排序 核心思想 具体步骤 代码实现 3.7、堆排序 3.8、计数排序 3.9、桶排序 3.10、基数排序 4、字符串匹…

QT自带PDF库的使用

QT自带PDF库可以方便的打开PDF文件&#xff0c;并将文件解析为QImage&#xff0c;相比网上提供的开源库&#xff0c;QT自带PDF库使用更方便&#xff0c;也更加可靠&#xff0c;然而&#xff0c;QT自带PDF库的使用却不同于其他通用库的使用&#xff0c;具备一定的技巧。 1. 安装…

【深度学习】Transformer,Self-Attention,Multi-Head Attention

必读文章&#xff1a; https://blog.csdn.net/qq_37541097/article/details/117691873 论文名&#xff1a;Attention Is All You Need 文章目录 1、Self-Attention 自注意力机制2、Multi-Head Attention 1、Self-Attention 自注意力机制 Query&#xff08;Q&#xff09;表示当…