当前位置: 首页 > wzjs >正文

怎么做钓鱼网站微信扫码点餐小程序

怎么做钓鱼网站,微信扫码点餐小程序,公司需要做网站吗,安卓app生成器目录 剑指 Offer 04二维数组中的查找 代码解析 剑指 Offer 11旋转数组的最小数字 代码解析1 代码解析2 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 代码解析1 代码解析2 剑指 Offer 04二维数组中的查找 LCR 121. 寻找目标值 - 二维数组 - 力扣(LeetCo…

目录

剑指 Offer 04二维数组中的查找

代码解析

剑指 Offer 11旋转数组的最小数字

代码解析1

代码解析2

剑指 Offer 21. 调整数组顺序使奇数位于偶数前面

代码解析1

代码解析2


剑指 Offer 04二维数组中的查找

LCR 121. 寻找目标值 - 二维数组 - 力扣(LeetCode)

m*n 的二维数组 plants 记录了园林景观的植物排布情况,具有以下特性:

  • 每行中,每棵植物的右侧相邻植物不矮于该植物;
  • 每列中,每棵植物的下侧相邻植物不矮于该植物。

请判断 plants 中是否存在目标高度值 target

示例 1:

输入:plants = [[2,3,6,8],[4,5,8,9],[5,9,10,12]], target = 8输出:true

示例 2:

输入:plants = [[1,3,5],[2,5,7]], target = 4输出:false

提示:

  • 0 <= n <= 1000
  • 0 <= m <= 1000
class Solution {
public:bool findTargetIn2DPlants(vector<vector<int>>& plants, int target) {};

代码解析

这个在C语言写过类似的杨氏矩阵,重点是查找的过程是排除的过程,这里从右上角开始找:

class Solution {
public:bool findTargetIn2DPlants(vector<vector<int>>& plants, int target) {if(plants.size()<1 || plants[0].size()<1) return false;int x=0,y=plants[0].size()-1;while(x < plants.size() && y >=0){if(plants[x][y]>target){y--;}else if(plants[x][y]<target){x++;}else{return true;}}return false;}
};

剑指 Offer 11旋转数组的最小数字

LCR 128. 库存管理 I - 力扣(LeetCode)

仓库管理员以数组 stock 形式记录商品库存表。stock[i] 表示商品 id,可能存在重复。原库存表按商品 id 升序排列。现因突发情况需要进行商品紧急调拨,管理员将这批商品 id 提前依次整理至库存表最后。请你找到并返回库存表中编号的 最小的元素 以便及时记录本次调拨。

示例 1:

输入:stock = [4,5,8,3,4]
输出:3

示例 2:

输入:stock = [5,7,9,1,2]
输出:1

提示:

  • 1 <= stock.length <= 5000
  • -5000 <= stock[i] <= 5000
class Solution {
public:int stockManagement(vector<int>& stock) {};

代码解析1

线性探测:

class Solution {
public:int stockManagement(vector<int>& stock) {for (int i = 1;i < stock.size();i++){if (stock[i] < stock[i - 1]) {return stock[i];}}return stock[0];}
};

代码解析2

二分查找+线性探测:

class Solution {
public:int stockManagement(vector<int>& rotateArray) {if (rotateArray.empty()){return 0;}int left = 0, right = rotateArray.size() - 1, mid = 0;while (left < right){if (right - left == 1) // 两个下标已经相邻了{mid = right;break;}mid = left + ((right - left) >> 1); // 注意操作符优先级if (rotateArray[mid] == rotateArray[left] && rotateArray[left] == rotateArray[right]) { // 无法判定目标数据在mid左侧,还是右侧 -> 采用线性探测方式int result = rotateArray[left];for (int i = left + 1; i < right; i++) {if (result > rotateArray[i]) {result = rotateArray[i];}}return result;}if (rotateArray[mid] >= rotateArray[left])  //说明mid在前半部分{ //两者相等, 隐含条件rotateArray[left] >= rotateArray[right]left = mid;}else  // 说明mid在后半部分{right = mid;}}return rotateArray[mid];}
};

剑指 Offer 21. 调整数组顺序使奇数位于偶数前面

LCR 139. 训练计划 I - 力扣(LeetCode)

教练使用整数数组 actions 记录一系列核心肌群训练项目编号。为增强训练趣味性,需要将所有奇数编号训练项目调整至偶数编号训练项目之前。请将调整后的训练项目编号以 数组 形式返回。

示例 1:

输入:actions = [1,2,3,4,5]
输出:[1,3,5,2,4] 
解释:为正确答案之一

提示:

  • 0 <= actions.length <= 50000
  • 0 <= actions[i] <= 10000
class Solution {
public:vector<int> trainingPlan(vector<int>& nums) {};

代码解析1

class Solution {
public:vector<int> trainingPlan(vector<int>& nums) {int left = 0, right = nums.size() - 1;while (left < right) {while (left < right && nums[left] % 2 == 1) {left++; // 找偶数}while (left < right && nums[right] % 2 == 0) {right--; // 找奇数}if (left < right) {swap(nums[left++], nums[right--]);}}return nums;}
};

代码解析2

如果面试官要求奇数和奇数,偶数和偶数直接的相对位置不变,就要用到插入排序的思想,

代码就是从前往后找奇数,然后把找到的奇数前面的偶数整体往后移一步,把奇数放到前面。

这里还用到奇数按位与1等于1,偶数按位与1等于0的技巧,第一种代码也能用这个技巧

class Solution {
public:vector<int> trainingPlan(vector<int>& nums) { // 相对位置不变版代码int k = 0, size = nums.size(); // k记录放奇数的下标for(int i = 0; i < size; ++i){if(nums[i] & 1) // 是奇数{int tmp = nums[i];for(int j = i; j > k; --j) // 移动偶数{nums[j] = nums[j - 1];}nums[k++] = tmp;}}return nums;}
};

文章转载自:

http://cyRaG4Cd.fqpyj.cn
http://Y8HcBHWj.fqpyj.cn
http://NOVEj7JH.fqpyj.cn
http://jkpAfIvU.fqpyj.cn
http://u4RvZhga.fqpyj.cn
http://8x1fYFqE.fqpyj.cn
http://8yJJ1LlB.fqpyj.cn
http://MXMTu2ho.fqpyj.cn
http://9OpjTVkx.fqpyj.cn
http://DnpuwrhG.fqpyj.cn
http://6XgWbYp1.fqpyj.cn
http://s7US9hCR.fqpyj.cn
http://sCNgoH4p.fqpyj.cn
http://t2642yZY.fqpyj.cn
http://eIMYKOYk.fqpyj.cn
http://3XFh8AH4.fqpyj.cn
http://XF2cZRtf.fqpyj.cn
http://ik8tu33e.fqpyj.cn
http://HNyewNol.fqpyj.cn
http://Af01EzWe.fqpyj.cn
http://N0ERaT3U.fqpyj.cn
http://2WUgIR6S.fqpyj.cn
http://GkYS0J8q.fqpyj.cn
http://CVPJD6V6.fqpyj.cn
http://RzEO1DPt.fqpyj.cn
http://oWUaR5LJ.fqpyj.cn
http://7gZ4GbD9.fqpyj.cn
http://NuboLHGW.fqpyj.cn
http://9ypz0ojN.fqpyj.cn
http://1v17aA5z.fqpyj.cn
http://www.dtcms.com/wzjs/669825.html

相关文章:

  • 网站不用下载免费软件网址seo优化排名
  • 建网站公司用什么网站程序石家庄网站优化
  • wordpress网站地图生成联客易外贸网站建设推广
  • 江苏国家住房和城乡建设部网站php做网站安全性
  • 江苏昆山网站建设大连网站建设主页
  • 南京做网站需要多少钱网站建设捌金手指下拉六
  • 购物网站开发历史怎么样让百度收录网站
  • 新闻资讯网站怎么做怎么自己做论坛网站
  • wordpress网站怎么进去wordpress获取专题名
  • 全球最大购物网站数字营销云
  • 曲阜市古建设计院网站做销售在哪些网站发贴
  • 录播教育系统网站建设费用企业邮箱号怎么注册
  • 网站基站的建设北京化妆品网站建设
  • 专门做素菜的网站wordpress 分类 模板
  • 怒江网站制作提供网站建设备案公司
  • 建设玩偶网站最终目的怎么做可以聊天的网站吗
  • 买网站做设计参考属于什么费用seo网站推广 杭州
  • 摄影网站建设的论文wordpress用户组插件
  • 网站模板的修改罗湖商城网站设计公司
  • 网站个人中心设计网站程序免费下载
  • 制作简易网站做的不好的网站
  • 厦门网站建设找哪家免费手机网站源码下载
  • 做网站需要什么编程语言电商推广渠道有哪些
  • 关于婚纱摄影的网站模板成都做网站设计哪家好
  • 桂林什么公司做网站推广好东方网络律师团队
  • dw做一个小网站教程小游戏 打开
  • pc端和手机端网站建设网站开发文献综述
  • 宜兴做网站的公司公司网站页脚
  • 石家庄网站建设找哪家吐鲁番做网站
  • 哪里有建设网站中的视频下载权重网站建设