剑指29.顺时针打印矩阵 31 栈的压入,弹出序列 03 数组中的重复数字 53缺失的数字 04二维数组中的查找

在这里插入图片描述

class Solution {
public:vector<int> spiralOrder(vector<vector<int>>& matrix) { if (matrix.size() == 0 || matrix[0].size() == 0return {};//必须要写到最前面,因为right和bottom-1就是负数了vector<int> result;int left=0,right=matrix[0].size()-1;//从一行的第一个lleft到最后一个rightint top=0,bottom=matrix.size()-1;//从一列的最上面到最下面int i=0,j=0;while(1){for(int i=left;i<=right;i++){ result.push_back(matrix[top][i]);}top++;if(top>bottom) break;for(int j=top;j<=bottom;j++){result.push_back(matrix[j][right]);}right--;if(left>right) break;for(int i=right;i>=left;i--){result.push_back(matrix[bottom][i]);}bottom--;if(top>bottom) break;for(int j=bottom;j>=top;j--){result.push_back(matrix[j][left]);}left++;if(left>right) break;}return result;}
};

回字形
在这里插入图片描述
思路:pushed数组里遍历进栈,遍历时候,先进栈,再判断栈顶是否和poped序列的当前指向的是否一样,一样就pop,直到不一样为止,然后继续遍历进栈。然后再判断栈里面剩余的和poped序列指向的一不一样,一样,就把栈里面的pop,直到栈为空,只要有一个不一样,就return 0,最后栈为空,poped序列也遍历完了,flag=1.
在这里插入图片描述
这题用的哈希集合,想着一会就写出来了,但是,算了先贴出脑残代码,尼玛哈希集合的count值只能是找不到(0),找得到(1),没有其他的取值!!!!!!我说怎么给我return 0呢!!我真是个大蠢货

class Solution {
public:int findRepeatNumber(vector<int>& nums) {unordered_set<int> hs;for(int i=0;i<nums.size();i++){hs.emplace(nums[i]);//比emplace更高效率的插入if(hs.count(nums[i])>1) return nums[i];//count只能是0,1}return 0;}
};

稍稍改一下就行了

class Solution {
public:int findRepeatNumber(vector<int>& nums) {unordered_set<int> hs;for(int i=0;i<nums.size();i++){if(hs.count(nums[i])==1) return nums[i];hs.emplace(nums[i]);//比emplace更高效率的插入}return 0;}
};

这边记录一下为什么empalce比insert更高效,emplace是调用拷贝构造函数(一气呵成),构造插入元素的时候已经赋值;inset是先构造一个元素,再调用重载运算符号,进行赋值
当然push_back也是属于先构造元素,然后调用重载运算符进行赋值,不太行
在这里插入图片描述
哈希表

class Solution {
public:int search(vector<int>& nums, int target) {unordered_map<int,int>mp;for(int i=0;i<nums.size();i++){mp[nums[i]]++;}return mp[target];}
};

在这里插入图片描述

class Solution {
public:int missingNumber(vector<int>& nums) {int val=nums[0];int res=0;for(int i=0;i<nums.size();i++){if(nums[i]!=val++) return val-1;if(i==nums.size()-1){if(nums[0]==1) return 0;//特殊情况 只有一个元素【1】的时候,缺的是0,不是2res=nums[i]+1;}}return res;}
};

在这里插入图片描述

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

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

相关文章

ELK-日志服务【kafka-配置使用】

kafka-01 10.0.0.21 kafka-02 10.0.0.22 kafka-03 10.0.0.23 【1】安装zk集群、配置 [rootes-01 ~]# yum -y install java maven [rootes-01 ~]# tar xf apache-zookeeper-3.5.9-bin.tar.gz -C /opt/[rootes-01 ~]# cd /opt/apache-zookeeper-3.5.9-bin/conf/ [rootes-…

爬虫相关知识与面试题目

常见的反爬虫和应对方法 参考:https://www.cnblogs.com/bsdr/p/5151891.html 0x01 常见的反爬虫 这几天在爬一个网站&#xff0c;网站做了很多反爬虫工作&#xff0c;爬起来有些艰难&#xff0c;花了一些时间才绕过反爬虫。在这里把我写爬虫以来遇到的各种反爬虫策略和应对的…

剑指offer33.二叉搜索树的后序遍历序列

我一开始的想法是&#xff1a;后序遍历是左右根&#xff0c;那么第一个数小于第二个数&#xff0c;第二个数大于第三个数&#xff0c;然后从第三个数开始又循环&#xff0c;显然错了&#xff0c;因为我这种是理想情况&#xff0c;是一个满二叉树。正确的解法是: class Solutio…

正则表达式

一、正则表达式基本介绍 1. 介绍 一个正则表达式&#xff0c;就是用某种模式去匹配字符串的一个公式。很多人因为它们看上去比较古怪而且复杂所以不敢去使用&#xff0c;不过,经过练习后,就觉得这些复杂的表达式写起来还是相当简单的&#xff0c;而且&#xff0c;一旦你弄懂它…

python求解纳什均衡

背景知识 双人纳什均衡求解问题&#xff0c;假设&#xff1a; 玩家 0 0 0&#xff0c;行动 { 0 , ⋯ , m − 1 } \{0, \cdots, m-1\} {0,⋯,m−1}&#xff0c;收益 A ∈ R m n A \in \reals_{}^{m \times n} A∈Rmn​&#xff0c;策略 p ∈ R m 1 p \in \reals_{}^{m \ti…

AA@有理系数多项式@整系数多项式@本原多项式@有理多项式可约问题

文章目录 有理系数多项式本原多项式一般多项式到整系数多项式本原多项式定义高斯引理整系数多项式分解定理推论思路1:思路2:思路3:(废弃) 整系数多项式有理根定理与整根定理爱森斯坦判别法构造任意次数的有理系数不可约多项式 有理系数多项式 有理数域上一元多项式的因式分解.…

Shuffle简单理解

map的结果本身是无序的&#xff0c;但是map输出的结果有序 mapper和reduce是不同的机器&#xff0c;进行了网络传输&#xff0c;所以存在数据拷贝 第二次排序&#xff0c;是将每个reduce对应的task进行排序&#xff0c;然后再进入reduce maptask运行结束&#xff0c;每个mask块…

JS制作一个网页版的猜数字小游戏

一. 网络游戏简介 在输入框内输一个数字&#xff0c;点击后面的“猜”按钮&#xff0c;系统会根据你猜的数字的大小&#xff0c;返回你是猜大猜小还是猜正确&#xff0c;系统还会统计你猜的次数&#xff0c;在猜数字的途中你点击按钮随时可以重新开始游戏 页面框架&#xff1…

能耗管理平台保障用电的安全

安科瑞虞佳豪 壹捌柒陆壹伍玖玖零玖叁 6月12日&#xff0c;江苏盐城射阳县某民房起火&#xff0c;消防救援人员到场后&#xff0c;立即对火势进行扑救&#xff0c;经过20多分钟的处置&#xff0c;现场明火全部被扑灭&#xff0c;据了解&#xff0c;起火原因是电线老化短路引发…

短视频seo抖音矩阵号系统源码开发搭建分享

我们自主研发的短视频矩阵系统源码&#xff0c;技术研发的独立核心算法的视频内容管理和展示功能。无需额外的流量接口费用和复杂的配置&#xff0c;轻松地创建和管理短视频内容&#xff0c;短视频矩阵源码是指将抖音平台上的视频资源进行筛选、排序等操作&#xff0c;进而提升…

Ubuntu 查看磁盘空间大小命令

df命令是Linux系统以磁盘分区为单位查看文件系统&#xff0c;可以加上参数查看磁盘剩余空间信息&#xff0c;命令格式&#xff1a; df -hl 显示格式为&#xff1a;  文件系统 容量 已用 可用 已用% 挂载点  Filesystem Size Used Avail Use% Mou…

48、MyBatis的优缺点

MyBatis的优缺点 优点 基于 SOL 语句编程&#xff0c;相当灵活&#xff0c;不会对应用程序或者数据库的现有设计造成任何影响&#xff0c;SQL 写在 XML里&#xff0c;解除 sql 与程序代码的合&#xff0c;便于统一管理&#xff0c;提供 XML 标签&#xff0c;支持编写动态 SQL…

Redis简介(1)

⭐ 作者简介&#xff1a;码上言 ⭐ 代表教程&#xff1a;Spring Boot vue-element 开发个人博客项目实战教程 ⭐专栏内容&#xff1a;个人博客系统 ⭐我的文档网站&#xff1a;http://xyhwh-nav.cn/ 文章目录 Redis简介1、NoSQL1.1、什么是NoSQL&#xff1f;1.2、NoSQL 特点…

【java爬虫】使用selenium获取某宝联盟淘口令

上一篇文章我们已经介绍过使用selenium获取优惠券基本信息的方法 (15条消息) 【java爬虫】使用selenium爬取优惠券_haohulala的博客-CSDN博客 本文将在上一篇文章的基础上更进一步&#xff0c;获取每个优惠券的淘口令&#xff0c;毕竟我们只有复制淘口令才能在APP里面获取优惠…

C++day4 (拷贝构造函数、拷贝赋值函数、匿名对象、友元函数、常成员函数、常对象、运算符重载)

#include <iostream> #include <cstring> using namespace std;class mystring { private:char *str; //记录C风格字符串int size; //记录字符串的实际长度public://无参构造mystring():size(10){strnew char[size];//构造出一个长度为10的字符串strcpy(str,&…

汽车的空气悬架的功能以及发展趋势

空气悬架能实现什么功能以及发展趋势 了解空气悬架之前,首先得快速了解什么是悬架。 教科书说法是: 悬架系统是汽车的车架与车桥或车轮之间的一切传力连接装置的总称。悬架系统基本构成有弹性元件(各类弹簧,缓冲作用);减震元件(减震器,减震作用);导向机构(控制臂等…

《网络是怎样连接的》(一)

本文主要取材于 《网络是怎样连接的》 第一章。 简述&#xff1a;在浏览器输入一个网址&#xff0c;浏览器会解析出域名&#xff0c;但是直接使用域名无法找到Web服务器。需要使用DNS解析器将域名解析为IP地址&#xff0c;然后客户端可以创建套接字&#xff0c;延伸出管道根据…

浅谈设计模式之单例模式

0 单例模式简介 单例模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。单例模式指的是单一的一个类&#xff0c;该类负责创建自己的对象&#xff0c;并且保证该对象唯一。该类提供了一种访问其唯一对象的方法&#xff0c;外部需要调用该类的对象可以通过方法获…

编译报错:The project is using an incompatible version

The project is using an incompatible version (AGP 8.0.2) of the Android Gradle plugin. Latest supported version is AGP 7.4.1 See Android Studio & AGP compatibility options. 注意AndroidStudio版本和AGP的版本&#xff0c;需要对应。 如果不对应需要下载对应的…

python发送邮件zmail库

第三方库“zmail”和“yagmail”可实现邮件发送。在实际使用对比zmail比yagmail更简洁。使用zmail&#xff0c;无需登录OA邮箱&#xff0c;便可完成邮件的发送及附件的自动加载。 import zmaildef send_zmail(sender, sender_password, addressee, host, port465, inspect_smtp…