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

基础数据结构之——【顺序表】(上)

从今天开始更新数据结构的相关内容。(我更新博文的顺序一般是按照我当前的学习进度来安排,学到什么就更新什么(简单来说就是我的学习笔记),所以不会对一个专栏一下子更新到底,哈哈哈哈哈哈哈!!!😄)


本专栏以力扣为落脚点,以实际题目为依据来进行相应知识点的讲解和应用,希望对你能有所帮助!

废话不多说,我们直接开始!
在这里插入图片描述


文章目录

  • :fire:LC 2057 ----值相等的最小索引(简单)
      • :star:二分查找(Binary Search):
  • :fire:LC 1464 ----数组中两元素的最大乘积(简单)
      • :star:sort函数:
  • :fire:LC 485----最大连续 1 的个数(简单)
  • :fire:LC 27---- 移除元素(简单)
      • :star:vector中删除元素的方法总结:
  • :fire:LC 665----非递减数列(中等)


🔥LC 2057 ----值相等的最小索引(简单)

题目链接:https://leetcode.cn/problems/smallest-index-with-equal-value/

题目简介:

给你一个下标从 0 开始的整数数组 nums ,返回 nums 中满足 i mod 10 == nums[i] 的最小下标 i ;如果不存在这样的下标,返回 -1 。

  • x mod y 表示 x 除以 y 的 余数 。

这道题就很简单了,按照题目说的条件,直接线性枚举(可以理解为直接遍历)一遍,就可找出答案。

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

代码示例:


class Solution {
public:int smallestEqual(vector<int>& nums) {//获取数组长度int n=nums.size();for(int i=0;i<n;i++){if(i%10==nums[i]) return i;}return -1;}
};

可能会有人问,二分查找行不行,答案是不行!因为nums数组的元素之间并没有特定的联系(是无序的),不适合二分。

既然谈到了,那就简单说说什么是二分吧。

⭐️二分查找(Binary Search):

是一种在有序数组中查找目标值的算法。它通过将目标值与数组的中间元素进行比较,从而确定目标值可能存在的位置。

下面是一个简单的函数模板:

int firstBadVersion(int *arr,int n) {//定义左右边界,这里我称left和right为游标,而不是指针!避免混淆
int left=-1,right=n;//定义中点
int mid=0;//进行二分
while(right-left>1){//记录中点
mid=left+(right-left)/2;//满足条件时:
if(arr[mid]满足条件){//移动游标
right=mid;
}
//不满足条件时:
else{
left=mid;
}
}
return right;
}
  1. 可能有人会问,游标为什么要取-1和n,不能取0和n-1吗?他们的中点不应该一样吗?

    答:其实这是为了避免极端情况的发生,如果左右边界(即0和n-1)满足条件时,二分查找会出错,你可以想想为什么。

  2. 换位置时,一定是满足条件时换right吗?

    答:不一定,这个得具体情况具体分析!


🔥LC 1464 ----数组中两元素的最大乘积(简单)

题目链接:https://leetcode.cn/problems/maximum-product-of-two-elements-in-an-array/?envType=list&envId=7q99qCXM

题目简介:

给你一个整数数组 nums,请你选择数组的两个不同下标 i 和 j,使 (nums[i]-1)*(nums[j]-1) 取得最大值。
请你计算并返回该式的最大值。

代码示例:

class Solution {
public:int maxProduct(vector<int>& nums) {//这里直接调用sort函数排序:sort(nums.begin(),nums.end());//获取数组长度int len=nums.size();//返回结果return (nums[len-1]-1)*(nums[len-2]-1);}
};

这里我们用到了sort函数,sort函数的时间复杂度通常为O(n log n),所以我决定写一个O(n)的解法出来:

class Solution {
public:int maxProduct(vector<int>& nums) {int n=nums.size();int max=0;//最大值int maxIndex;//最大值索引int sec=0;//次大值int secIndex;//次大值索引int i,j;//寻找最大值和其索引for(i=0;i<n;i++){if(nums[i]>max) {max=nums[i];maxIndex=i;}}//寻找次大值和其索引for(j=0;j<n;j++){if(j!=maxIndex){if(nums[j]>sec) {        sec=nums[j];   secIndex=j;            }}}int maxSum=(max-1)*(sec-1);return maxSum;}
};

既然用到了sort函数,那就来简单介绍一下:

⭐️sort函数:

是一种常见的排序算法,它能够将一个数组或容器中的元素按照指定的排序规则进行排列。

  • 在C++语言中,sort函数在< algorithm >头文件中。
  • 基本形式:sort(first,end,comp)

其中,first和last是表示待排序范围的迭代器,comp是一个可选的比较函数,用于指定排序规则。如果不提供comp参数,则默认按照升序排序。要想降序的话,第三个参数可以写成greater<int>(),其中<>里面也可以写double,long,float等等

  • 总的来说:
    升序:sort(first,end,cmp)或者sort(first,end)
    降序:sort(first,end,greater<int>())

🔥LC 485----最大连续 1 的个数(简单)

题目链接:https://leetcode.cn/problems/max-consecutive-ones/?envType=list&envId=7q99qCXM

题目简介:

给定一个二进制数组 nums , 计算其中最大连续 1 的个数。

代码示例:

class Solution {
public:int findMaxConsecutiveOnes(vector<int>& nums) {int n=nums.size();//最长1的个数int maxLenOne=0;//计数器:1出现的个数int countOne=0;for(int i=0;i<n;i++){if(nums[i]==1) countOne++;//计数器:遇1自增else{          maxLenOne= (maxLenOne>countOne)?maxLenOne:countOne;//对长度赋值countOne=0;//计数器归0}}//边界值:可能最后一个数不是0,所以最后一段1的值没有被比较,在此比较一次,防止遗漏最优解maxLenOne= (maxLenOne>countOne)?maxLenOne:countOne;return maxLenOne;}
};

🔥LC 27---- 移除元素(简单)

题目链接:https://leetcode.cn/problems/remove-element/?envType=list&envId=7q99qCXM

题目简介:

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

代码示例:

class Solution {
public:int removeElement(vector<int>& nums, int val) {// int n=0;for(int i=0;i<nums.size();i++){if(nums[i]==val){// n=i;nums.erase(nums.begin()+i);i=i-1;}}return nums.size();}
};

这里就是一个线性枚举,然后对当前值进行一个判断,如果等于目标值,就将其删除,用到了vector:erase()函数。

⭐️vector中删除元素的方法总结:

vector中删除元素大概有这么几种方法:

  • nums.pop_back(); //删除最后一个元素
  • nums.clear(); //清空nums中的元素
  • nums.erase(nums.begin()+i,nums.begin()+j); //删除nums中从第i+1个元素到第j+1个的所有元素,也就是索引[i,j]。写成nums.erase(nums.begin()+i)就是直接删除第i+1个元素(下标为i)

🔥LC 665----非递减数列(中等)

题目链接:https://leetcode.cn/problems/non-decreasing-array/?envType=list&envId=7q99qCXM

题目简介:

给你一个长度为 n 的整数数组 nums ,请你判断在 最多 改变 1 个元素的情况下,该数组能否变成一个非递减数列。
我们是这样定义一个非递减数列的: 对于数组中任意的 i (0 <= i <= n-2),总满足 nums[i] <= nums[i + 1]。

代码示例:

class Solution {
public:bool checkPossibility(vector<int>& nums) {int n=nums.size();if(n==1 || n==2) return true;int count=0;int count1=0;int count2=0;vector<int>num1(nums);vector<int>num2(nums);for(int i=1;i<n;i++){if(nums[i]<nums[i-1]){                                        nums[i-1]=nums[i];                break; }   }for(int i=1;i<n;i++){if(num1[i]<num1[i-1]){num1[i]=num1[i-1];        break;}    }for(int i=1;i<n;i++){if(num2[i]<num2[i-1]){if(i+1<n){num2[i]=num2[i+1];    break; } else num2[i]=num2[n-2];                         }    }        for(int i=1;i<n;i++){if(num1[i]<num1[i-1]) count1=1;if(nums[i]<nums[i-1]) count=1;if(num2[i]<num2[i-1]) count2=1;if(count==1 && count==1 && count2==1) return false;}  return true;}
};

这道题我用的是枚举的方法,暂时没啥更优化的方法,以后想到了会进行更新!


在这里插入图片描述

相关文章:

基础数据结构之——【顺序表】(上)

从今天开始更新数据结构的相关内容。&#xff08;我更新博文的顺序一般是按照我当前的学习进度来安排&#xff0c;学到什么就更新什么&#xff08;简单来说就是我的学习笔记&#xff09;&#xff0c;所以不会对一个专栏一下子更新到底&#xff0c;哈哈哈哈哈哈哈&#xff01;&a…...

Apollo自动驾驶系统概述(文末参与活动赠送百度周边)

前言 「作者主页」&#xff1a;雪碧有白泡泡 「个人网站」&#xff1a;雪碧的个人网站 「推荐专栏」&#xff1a; ★java一站式服务 ★ ★ React从入门到精通★ ★前端炫酷代码分享 ★ ★ 从0到英雄&#xff0c;vue成神之路★ ★ uniapp-从构建到提升★ ★ 从0到英雄&#xff…...

Java 21 新特性:Unnamed Classes and Instance Main Methods

Java 21引入了两个语言核心功能&#xff1a; 未命名的Java类你说新的启动协议&#xff1a;该协议允许更简单地运行Java类&#xff0c;并且无需太多样板 下面一起来看个例子。通常&#xff0c;我们初学Java的时候&#xff0c;都会写类似下面这样的 Hello World 程序&#xff1…...

Tomcat启动后的日志输出为乱码

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…...

CSP-J第二轮试题-2021年-4题

文章目录 参考&#xff1a;总结 [CSP-J 2021] 小熊的果篮题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 样例 #2样例输入 #2样例输出 #2 样例 #3样例输入 #3样例输出 #3 提示答案答案1答案2答案3 现场真题注意事项 参考&#xff1a; https://www.luogu.com.cn/probl…...

10.1 今日任务:select实现服务器并发

#include <myhead.h>#define ERR_MSG(msg) do{\fprintf(stderr, "__%d__:", __LINE__); \perror(msg);\ }while(0)#define PORT 8888 //端口号&#xff0c;范围1024~49151 #define IP "192.168.112.115" //本机IP&#xff0c;ifco…...

P1540 [NOIP2010 提高组] 机器翻译(模拟)

[NOIP2010 提高组] 机器翻译 题目背景 小晨的电脑上安装了一个机器翻译软件&#xff0c;他经常用这个软件来翻译英语文章。 题目描述 这个翻译软件的原理很简单&#xff0c;它只是从头到尾&#xff0c;依次将每个英文单词用对应的中文含义来替换。对于每个英文单词&#xf…...

生信教程:ABBA-BABA分析之滑动窗口

简介 ABBA BABA 统计&#xff08;也称为 D 统计&#xff09;为偏离严格的分叉进化历史提供了简单而有力的检验。因此&#xff0c;它们经常用于使用基因组规模的 SNP 数据测试基因渗入。 虽然最初开发用于基因渗入的全基因组测试&#xff0c;但它们也可以应用于较小的窗口&#…...

二分答案(求最大值的最小值||求最小值的最大值)

引入 二分答案要建立在二分查找的基础上&#xff0c;在此之前&#xff0c;要知道二分查找的三个模板 模板一 while(l<r) {int mid(lr)>>1;if(check(mid)) rmid;else lmid1; }模板二 while(l<r) {int midlr1>>1;if(check(mid)) lmid;else rmid-1; }模板三…...

思维模型 周期

本系列文章 主要是 分享 思维模型&#xff0c;涉及各个领域&#xff0c;重在提升认知。周期是一个看似极为简单&#xff0c;但背后却蕴藏着大智慧的模型&#xff0c;了解周期&#xff0c;对于了解王朝更替&#xff0c;数学之美&#xff0c;经济运转等都有帮助。 1 周期的应用 …...

从 0 到 1 ,手把手教你编写《消息队列》项目(Java实现) —— 介绍项目/ 需求分析

文章目录 一、消息队列是什么&#xff1f;二、需求分析结构解析功能解析规则解析绑定关系交换机类型消息应答 三、持久化存储四、网络通信提供的API复用TCP连接 五、消息队列概念图 一、消息队列是什么&#xff1f; 消息队列 (Message Queue, MQ)就是将阻塞队列这一数据结构提取…...

Python学习之索引与切片

Python学习之索引与切片 s “0abcdefghijklmnopqrstuvwxyz”&#xff0c;第一个元素‘0’&#xff0c;索引号为0&#xff0c;最后一个元素‘z’&#xff0c;索引号为26 1. s[0]获取索引号为0的元素 2. s[1:3]获取索引号为1的元素&#xff0c;直到但不包括索引号为3的元素。即…...

编程每日一练(多语言实现)基础篇:满足abcd=(ab+cd)^2的数 (增加Go语言实现)

文章目录 一、实例描述二、技术要点三、代码实现3.1 C 语言实现3.2 Python 语言实现3.3 Java 语言实现3.4 JavaScript 语言实现3.5 Go 语言实现 一、实例描述 假设 abcd 是一个四位整数&#xff0c;将它分成两段&#xff0c;即 ab 和 cd&#xff0c;使之相加求和后再平方。求满…...

LeetCode 热题 HOT 100:回溯专题

LeetCode 热题 HOT 100&#xff1a;https://leetcode.cn/problem-list/2cktkvj/ 文章目录 17. 电话号码的字母组合22. 括号生成39. 组合总和46. 全排列补充&#xff1a;47. 全排列 II &#xff08;待优化)78. 子集79. 单词搜索124. 二叉树中的最大路径和200. 岛屿数量437. 路径…...

喝健康白酒 有益生心健康

中国的制酒史源远流长&#xff0c;酒渗透在中华五千年的文化中。酒与烟不同&#xff0c;烟对人体有百害而无一利&#xff0c;而对于酒&#xff0c;若掌握好饮酒的度&#xff0c;对人体有一定的养生作用&#xff0c;所以我们通常会说“戒烟限酒”。 据一些专家研究&#xff0c;…...

动态规划:两个数组的dp问题(C++)

动态规划&#xff1a;两个数组的dp问题 前言两个数组的dp问题1.最长公共子序列&#xff08;中等&#xff09;2.不同的子序列&#xff08;困难&#xff09;3.通配符匹配&#xff08;困难&#xff09;4.正则表达式&#xff08;困难&#xff09;5.交错字符串&#xff08;中等&…...

BASH shell脚本篇2——条件命令

这篇文章介绍下BASH shell中的条件相关的命令&#xff0c;包括&#xff1a;if, case, while, until, for, break, continue。之前有介绍过shell的其它基本命令&#xff0c;请参考&#xff1a;BASH shell脚本篇1——基本命令 1. If语句 if语句用于在顺序执行语句的流程中执行条…...

【图论C++】Floyd算法(多源最短路径长 及 完整路径)

>>>竞赛算法 /*** file * author jUicE_g2R(qq:3406291309)————彬(bin-必应)* 一个某双流一大学通信与信息专业大二在读 * * brief 一直在算法竞赛学习的路上* * copyright 2023.9* COPYRIGHT 原创技术笔记&#xff…...

小谈设计模式(11)—模板方法模式

小谈设计模式&#xff08;11&#xff09;—模板方法模式 专栏介绍专栏地址专栏介绍 模板方法模式角色分类抽象类&#xff08;Abstract Class&#xff09;具体子类&#xff08;Concrete Class&#xff09;抽象方法&#xff08;Abstract Method&#xff09;具体方法&#xff08;C…...

C#程序中很多ntdll.dll、clr.dll的线程

如下图 需要“右键工程——调试——取消勾选‘启用本地代码调试’”即可。...

低代码工作流程管理系统:提升企业运营效率的利器

业务运营状况是否良好&#xff0c;除了人员需要配合以外&#xff0c;真正发挥作用的是背后的工作流程。将重复的工作进行自动化处理&#xff0c;确保这些流程最终指向同一个目标、实现一致的运营结果。而设计和实施不佳的工作流程则产生相反的效果——导致处理时间延长、运营成…...

HIVE SQL regexp_extract和regexp_replace配合使用正则提取多个符合条件的值

《平凡的世界》评分不错&#xff0c;《巴黎圣母院》改变成的电影不错&#xff0c;还有<<1984>>也蛮好看。 如何使用regexp_extract&regexp_replace函数将以上文本中所有书籍名称都提取出来&#xff1f; select substr(regexp_replace(regexp_extract(regexp_…...

debian 安装matlab2022b报错解决方法与问题解决思路

报错 terminate called after throwing an instance of ‘std::runtime_error’ 在安装目录执行 ./bin/glnxa64/MATLABWindow通过执行以上命令发现是和libharfbuzz库有关。 该库在调用freetype库时&#xff0c;有方法找不到。 偿试remove freetype库&#xff0c;发现该库有大…...

Jenkins集成AppScan实现

一、Jenkins上安装插件 在Jenkins里安装以下插件 ibm-security-appscanstandard-scanner 二、打开AppScan 1、配置需要扫描的地址 配置需要扫描的地址 2、记录好要扫描的URL登录序列 记录好要扫描的URL登录序列 3、导出要扫描的URL登录序列设置 导出要扫描的URL登录序列设置 三…...

10.1 File类

前言&#xff1a; java.io包中的File类是唯一一个可以代表磁盘文件的对象&#xff0c;它定义了一些用于操作文件的方法。通过调用File类提供的各种方法&#xff0c;可以创建、删除或者重命名文件&#xff0c;判断硬盘上某个文件是否存在&#xff0c;查询文件最后修改时间&…...

[论文笔记]UNILM

引言 今天带来论文Unified Language Model Pre-training for Natural Language Understanding and Generation的笔记,论文标题是 统一预训练语言模型用于自然语言理解和生成。 本篇工作提出了一个新的统一预训练语言模型(Unifield pre-trained Language Model,UniLM),可以同…...

LLM之Colossal-LLaMA-2:Colossal-LLaMA-2的简介、安装、使用方法之详细攻略

LLM之Colossal-LLaMA-2&#xff1a;Colossal-LLaMA-2的简介、安装、使用方法之详细攻略 导读&#xff1a;2023年9月25日&#xff0c;Colossal-AI团队推出了开源模型Colossal-LLaMA-2-7B-base。Colossal-LLaMA-2项目的技术细节&#xff0c;主要核心要点总结如下: >> 数据处…...

国庆作业2

select实现服务器并发 代码&#xff1a; #include <myhead.h>#define ERR_MSG(msg) do{\printf("%d\n",__LINE__);\perror(msg);\ }while(0)#define PORT 8888#define IP "192.168.1.5"int main(int argc, const char *argv[]) {//创建流式套接字…...

fork仓库的代码如何同步主仓库代码

1.背景 我fork了一份 jekyll-theme-chirpy 仓库的代码(基于 jekyll 的自建博客仓库&#xff0c;可以免服务器)&#xff0c;我需要在上面更新我的博客文章&#xff0c;但是我又想一直同步 jekyll-theme-chirpy 仓库的新功能&#xff0c;这样我可以更新自己的博客功能。所以我就…...

【Axure】元件库和母版、常见的原型规范、静态原型页面制作

添加现有元件库 点击元件库——载入 当然也可以创建元件库&#xff0c;自己画自己保存 建立京东秒杀母版 静态原型页面的制作 框架 选择以iphone8的界面大小为例&#xff0c;顶部状态栏高度为20 左侧类似于标尺&#xff0c;因为图标、文字离最左侧的间距是不一样的 信…...

在百度上做网站多少钱/最近发生的新闻

2019独角兽企业重金招聘Python工程师标准>>> ###第一章 ######与Elasticsearch交互 节点客户端(node client) 节点客户端以无数据节点(none data node)身份加入集群&#xff0c;换言之&#xff0c;它自己不存储任何数据&#xff0c;但是它知道数据在集群中的具体位置…...

绵阳做手机网站建设/搜索引擎优化是什么意思啊

海绵是一种日常较常见的多孔弹性材料&#xff0c;有良好的吸水性&#xff0c;生活中&#xff0c;人们常拿它当做清洁物品使用。海绵分天然海绵和和人工海绵&#xff0c;天然海绵常用于身体清洁和绘画&#xff0c;人工海绵则由于自身特性&#xff0c;广泛应用于汽车工业、电池工…...

什么网站做展板的多/今日中国新闻

我认为对于git初学者来说最令人困惑的是主要命令根据参数或上下文有多种用途&#xff0c;其中一些用法没有通过命令的名称来描述。 合并&#xff08;Merge) 合并不同的分支&#xff08;不同的历史&#xff0c;更确切地说&#xff09;如果不需要合并&#xff0c;则快进 ; 有效…...

合肥建站费用/手机搜索引擎

①如何写一个求阶层函数&#xff1f; fac 0 1 fac nn*fac(n-1) 函数自适应匹配参数&#xff0c;可以把特判情况写在前面&#xff0c;注意按顺序匹配的&#xff0c;n这种万能情况写在最前面就完蛋了。同时你也注意到&#xff0c;函数只能一行写完&#xff0c;不能智能识别作用域…...

邢台做wap网站/美食软文300范例

首先使用PL/SQL 通过语句&#xff1a;select * from v$version; 查询出使用的oracle版本&#xff0c;弄到对应版本的Oracle.DataAccess.DLL 我本地使用版本为&#xff1a;11.2.0.4.0 &#xff08;64位&#xff09;Oracle.DataAccess.DLL下载地址&#xff1a;https://www.orac…...

golang和php 做网站/服务营销包括哪些内容

package com.day10.Date类;import java.util.Date;public class DemoDate {/*** 常见对象(Date类的概述和方法使用)(掌握)* A:Date类的概述*    类 Date 表示特定的瞬间&#xff0c;精确到毫秒。* B:构造方法*    public Date()*   public Date(long date)* C:成员方法*…...