【算法与数据结构】【数组篇】【题6-题10】

news2024/10/6 20:35:27

系列文章

本人系列文章-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/handsomethefirst/article/details/138226266?spm=1001.2014.3001.5502


1.数组基本知识点

1.1概念

数组就是一个集合。数组会用一些名为索引的数字来标识每项数据在数组中的位置,且在大多数编程语言中,索引是从 0 算起的。我们可以根据数组中的索引,快速访问数组中的元素。

数组中的元素在内存中是连续存储的,且每个元素占用相同大小的内存。

1.2 相关操作的时间复杂度和空间复杂度

访问元素时间复杂度都是O(1),空间复杂度O(1),因为对于固定大小的数组,访问时间不随数组大小而变化。通过下标可直接访问。

修改元素:时间复杂度O(1),空间复杂度O(1),与n无关,通过下标可直接修改

插入元素和删除元素:时间复杂度O(1),空间复杂度O(1),插入和删除元素都需要移动后面的元素,因此随n变化。

题6

给你一个大小为 m x n 的矩阵 mat ,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素。

示例 1:

输入:mat = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,4,7,5,3,6,8,9]

示例 2:

输入:mat = [[1,2],[3,4]]
输出:[1,2,3,4]

 作题思路:

1.第一步:找规律,我们发现其每次遍历输出的x+y坐标的和是相等的。且当和为偶数的时候,是x递减,y递增,而当和为奇数的时候,是x递增,y递减。

[0,0]                 0  偶数
[0,1],[1,0]         1  奇数  
[2,0],[1,1],[0,2] 2  偶数
[1,2][2,1]          3  奇数
[2,2]                 4   偶数

2.第二步:查找遍历次数,不难发现其遍历的上限是m+n +1,此处m=M-1,n =N-1。

3.第三步:确定开始时,x位置和y的位置和结束时,x,y的位置。不难发现,

        当为偶数的时候,如果x+y=i,i的值小于最大的行数,代表坐标x从i开始,y从0开始,如果i大于等于最大的行数,代表坐标x从m开始,y=i-m开始。

        当为奇数的时候,如果x+y=i,i的值小于最大的列数,代表坐标y从i开始,x从0开始, 如果i大于等于最大的列数,代表坐标y从n开始,x=i-n开始

代码案例:

class Solution
{
public:
    vector<int> findDiagonalOrder(vector<vector<int>> &mat)
    {
        int m = mat.size() - 1;    // 横的长度
        int n = mat[0].size() - 1; // 竖的长度

        vector<int> returnvector;
        for (int i = 0; i < m + n + 1; i++)
        {
            if (i % 2 == 0) // 如果是偶数,其是向上遍历,因此其开始时候,x是大于y的,
            {
                int x = i < m ? i : m; // 如果i小于最大的行数,代表坐标x从i开始,y从0开始,如果i大于等于最大的行数,代表坐标x从m开始,y=i-m开始
                int y = i -x;

                while (x >= 0 && y <= n) // 注意x和y都不能越界
                {
                    returnvector.push_back(mat[x][y]);
                    x--;
                    y = i - x;
                }
            }
            else if (i % 2 == 1) // 如果是奇数,则是向下遍历
            {
                int y = i < n ? i : n; // 如果i小于最大的列数,代表坐标y从i开始,x从0开始, 如果i大于等于最大的列数,代表坐标y从n开始,x=i-n开始
                int x = i - y;

                while (x <= m && y >= 0) // 注意x和y都不能越界
                {

                    returnvector.push_back(mat[x][y]);
                    y--;
                    x = i - y;
                }
            }
        }
        return returnvector;
    }
};

题7

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。

不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

示例 1:

输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]

示例 2:

输入:s = ["H","a","n","n","a","h"]
输出:["h","a","n","n","a","H"]

 思路:

双指针:
双指针情形一:
指针向中间或两端移动,移动方向始终相对
双指针情形二:
指针向同侧移动,形成前后指针或快慢指针

第一步:定义两个指针,一个指向头位置,一个指向末尾位置。

第二步:交换元素。

第三步:移动头尾指针。

 代码案例:

class Solution
{
public:
    void reverseString(vector<char> &s)
    {
        int stringsize = s.size();
        if (stringsize <= 0)
        {
            return;
        }

        int head = 0;
        int tail = stringsize - 1;
        while (head <tail)
        {
            swap(s[head],s[tail]);
            head ++;
            tail --;
        }
    }
};

题8

给定长度为 2n 的整数数组 nums ,你的任务是将这些数分成 n 对, 例如 (a1, b1), (a2, b2), ..., (an, bn) ,使得从 1 到 n 的 min(ai, bi) 总和最大。

返回该 最大总和 。

示例 1:

输入:nums = [1,4,3,2]
输出:4
解释:所有可能的分法(忽略元素顺序)为:
1. (1, 4), (2, 3) -> min(1, 4) + min(2, 3) = 1 + 2 = 3
2. (1, 3), (2, 4) -> min(1, 3) + min(2, 4) = 1 + 2 = 3
3. (1, 2), (3, 4) -> min(1, 2) + min(3, 4) = 1 + 3 = 4
所以最大总和为 4

示例 2:

输入:nums = [6,2,6,5,1,2]
输出:9
解释:最优的分法为 (2, 1), (2, 5), (6, 6). min(2, 1) + min(2, 5) + min(6, 6) = 1 + 2 + 6 = 9

 思路:

要求 sum = a + b + c +...的最大值,那就每一个加数都尽量往大了取。首先考虑所有数的最大值,但是显然这个值不合要求,因为这里的每个加数都是通过min最小值得到的,最大值没有比它更大的,无法实现。那就考所有元素中虑第二大的值,第二大的值如果要作为min值被选出,那就必须得和最大值在一个组。这也是所有加数所能取得到的最大值。
最大值和次大值被选在一个组,剩下的元素中又会有新的最大值和次大值。依次类推。

 代码案例:

class Solution
{
public:
    int arrayPairSum(vector<int> &nums)
    {
        int arraysize = nums.size();
        sort(nums.begin(), nums.end());

        int sum = 0;

        for (int i = 0; i < arraysize; i = i + 2)
        {
            sum += nums[i];
        }

        return sum;
    }
};

题9

给你一个下标从 1 开始的整数数组 numbers ,该数组已按非递减顺序排列  ,请你从数组中找出满足相加之和等于目标数 target 的两个数。
如果设这两个数分别是 numbers[index1] 和 numbers[index2] ,则 1 <= index1 < index2 <= numbers.length 。

以长度为 2 的整数数组 [index1, index2] 的形式返回这两个整数的下标 index1 和 index2。

你可以假设每个输入 只对应唯一的答案 ,而且你 不可以 重复使用相同的元素。

你所设计的解决方案必须只使用常量级的额外空间。

示例 1:

输入:numbers = [2,7,11,15], target = 9
输出:[1,2]
解释:2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。返回 [1, 2] 。

示例 2:

输入:numbers = [2,3,4], target = 6
输出:[1,3]
解释:2 与 4 之和等于目标数 6 。因此 index1 = 1, index2 = 3 。返回 [1, 3]

 思路:

需要找到两个符合要求的值,优先双指针。

首先,是一个递增排序,那么我们可以知道头尾相加,判断最大值和最小值的和是否等于目标值,如果大于目标值,则说明我们值找大了,那就要找到次第二最大值,作为新区间的最大值,然后继续判断是否等于目标值。

如果是小于目标值,则说明我们值找小了,因此需要找到次第二最小值,作为新区间的最小值,然后继续判断是否等于目标值。

当等于的时候,则输出值。

代码案例

class Solution
{
public:
    vector<int> twoSum(vector<int> &numbers, int target)
    {
        int first = 0; 
        int tail = numbers.size() - 1;
        vector<int> returnvector;
        while (first < tail) 
        {

            if ((numbers[first] + numbers[tail]) == target) //首部尾部相加等于目标值,返回结果集
            {
                returnvector.push_back(first + 1);
                returnvector.push_back(tail + 1);
                return returnvector;
            }
            else if ((numbers[first] + numbers[tail]) > target)//首部尾部相加大于目标值,则说明尾部前移,值才能变小
            {
                tail--;
            }
            else if ((numbers[first] + numbers[tail]) < target)//首部尾部相加小于目标值,则首部后移,值才能变大
            {
                first++;
            }
        }
        return returnvector;
    }
};

题10

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。

假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作:

    更改 nums 数组,使 nums 的前 k 个元素包含不等于 val 的元素。nums 的其余元素和 nums 的大小并不重要。
    返回 k。

输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2,_,_]
解释:你的函数函数应该返回 k = 2, 并且 nums 中的前两个元素均为 2。
你在返回的 k 个元素之外留下了什么并不重要(因此它们并不计入评测)

 思路:

运用双指针的快慢指针,只有快指针不等于目标值的时候,才将快指针指向的值赋值给慢指针指向的值。这样慢指针指向的值就全都是去除了目标值的值。

 代码案例:

class Solution
{
public:
    int removeElement(vector<int> &nums, int val)
    {
        int slow = 0;
        int numsize = nums.size();

        for (int fast = 0; fast < numsize; fast++)
        {

            if (nums[fast] != val)
            {
                nums[slow] = nums[fast];
                slow++;
            }
        }

        return slow;
    }
};

 

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

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

相关文章

java float 无处不是陷阱

小数位随意&#xff0c;不确定。 public float payerAmt; 数据库是 decimal&#xff08;10,2&#xff09; 页面输入后&#xff0c;保存到数据库竟然是随意的一个小数点&#xff0c; 中间没有经过任何运算&#xff0c;输入 - 保存 <result column"payer_amt" …

计算机图形学入门08:反走样、滤波与卷积

1.抗锯齿(反走样) 在上一章中&#xff0c;在光栅化三角形的时候出现了明显的锯齿效果。如下图所示是三角形采样过程&#xff1a; 从图上可知像素点不是纯红色就是纯白色。如果在采样前先进行模糊操作(滤波)&#xff0c;如下图所示&#xff1a; 经过模糊操作后三角形的边缘颜色变…

了解多线程

1.线程与并发 1.1 理解进程和线程的区别 进程&#xff1a;是指一个内存中运行的应用程序&#xff08;程序的一次运行就产生一个进程&#xff09;&#xff0c;每个进程都有自己独立的一块内存空间&#xff0c;比如在Windows的任务管理器中&#xff0c;一个运行的xx.exe就是一个进…

一个热门的源码整站数据打包完整代码(开箱即用),集成了最新有效数据和完美wordpress主题。

分享一个资源价值几千元的好代码资源网整站打包代码&#xff0c;这个wordpress网站基于集成了ripro9.1完全明文无加密后门版本定制开发&#xff0c;无需独立服务器&#xff0c;虚拟主机也可以完美运营&#xff0c;只要主机支持php和mysql即可。整合了微信登录和几款第三方的主题…

AGP7+ 适配 plugin 动态引入第三方插件

AGP4 适配前 def hwPlugin com.huawei.agconnectmProject.getPlugins().apply(hwPlugin)AGP7 适配后 在 AGP4 如果仍然使用上述代码&#xff0c;那么编译期会报错&#xff0c;升级版本之后使用下面的pluginManager 即可。 def hwPlugin com.huawei.agconnectmProject.plug…

Studio One安装教程+软件安装包下载

Studio One6全新版本上线 记录、生产、混合、掌握和执行所有操作。从工作室到舞台&#xff0c;Studio One6以易用为核心&#xff0c;是您的创意合作伙伴。 当你准备好登上舞台时&#xff0c;Studio One就在那里。只有Studio One从最初的灵感到完整的制作&#xff0c;最终混音…

3D感知视觉表示与模型分析:深入探究视觉基础模型的三维意识

在深度学习与大规模预训练的推动下&#xff0c;视觉基础模型展现出了令人印象深刻的泛化能力。这些模型不仅能够对任意图像进行分类、分割和生成&#xff0c;而且它们的中间表示对于其他视觉任务&#xff0c;如检测和分割&#xff0c;同样具有强大的零样本能力。然而&#xff0…

(三十八)Vue之插槽Slots

文章目录 插槽介绍插槽分类默认插槽具名插槽条件插槽动态插槽名 作用域插槽默认作用域插槽具名作用域插槽 上一篇&#xff1a;&#xff08;三十七&#xff09;vue 项目中常用的2个Ajax库 插槽介绍 在之前的文章中&#xff0c;我们已经了解到组件能够接收任意类型的值作为 prop…

【品质】如何培养幽默感,如何幽默的沟通与应对生活(自卑vs自信,悲观vs乐观)

【品质】如何培养幽默感&#xff0c;如何幽默和正能量的沟通与应对生活&#xff08;自卑vs自信&#xff0c;悲观vs乐观&#xff09; 文章目录 一、性格底色&#xff08;自我认知&#xff0c;世界观&#xff09;1、从悲观的底色开始2、用摆烂、自嘲的方式与世界和解 二、沟通方法…

2024050802-重学 Java 设计模式《实战模板模式》

重学 Java 设计模式&#xff1a;实战模版模式「模拟爬虫各类电商商品&#xff0c;生成营销推广海报场景」 一、前言 黎明前的坚守&#xff0c;的住吗&#xff1f; 有人举过这样一个例子&#xff0c;先给你张北大的录取通知书&#xff0c;但要求你每天5点起床&#xff0c;12点…

mysql和redis备份和恢复数据的笔记

一、mysql的备份及恢复方法&#xff1a; 1.完全备份与恢复 1.1物理备份与恢复 物理备份又叫冷备份&#xff0c;需停止数据库服务&#xff0c;适合线下服务器 备份数据流程&#xff1a; 第一步:制作备份文件 systemctl stop mysqld #创建存放备份文件的目录 mkdir /bakdir …

医疗行业携手用友BIP收入云,开启高效收入管理新时代

在医疗行业&#xff0c;收入管理是实现可持续发展的重要环节。随着医疗改革的深入和市场竞争的加剧&#xff0c;医疗机构需要寻找有效的收入管理破局方法。用友BIP收入云作为一款强大的收入管理工具&#xff0c;为医疗行业提供了有力的支持。 一、医疗行业收入管理破局方法 精细…

多视图变换矩阵与SLAM位姿估计中的地图点投影的几何约束

定义 Homography & projective transform M ( 3 4 ) [ f s x c ′ 0 a f y c ′ 0 0 1 ] [ 1 0 0 0 0 1 0 0 0 0 1 0 ] [ R 3 3 0 3 1 0 1 3 1 ] [ I 3 3 T 3 1 0 1 3 1 ] \underset{(3 \times 4)}{\mathbf{M}}\left[\begin{array}{ccc} f & s & x_c^{\pr…

前端已学习内容

一、HTMLCSS 1、黑马B站视频-27小时 地址&#xff1a;基础班导学-精讲与实战_哔哩哔哩_bilibili 说明&#xff1a;讲义已下载。两个小项目还没学没练。 2、菜鸟教程 地址&#xff1a;HTML 简介 | 菜鸟教程 二、JavaScript 1、菜鸟教程 网址&#xff1a;JavaScript 教程 …

【点击收藏】鸿蒙HarmonyOS实战开发—如何实现应用悬浮窗

前言 鸿蒙登场&#xff01;它的征途是万物互联 备受瞩目的华为HarmonyOS 2&#xff08;即鸿蒙系统&#xff09;正式发布。同时&#xff0c;华为发布了多款搭载鸿蒙系统的新产品&#xff0c;包括Mate 40系列新版本、Mate X2新版本、华为WATCH 3系列、华为MatePad Pro等手机、智能…

vue-editor设置字体font-family

背景&#xff1a;Vue项目中需要用到富文本编辑器&#xff0c;所以选择了vue-editor这个富文本编辑器&#xff0c;发现字体font-family只有三种Sans Serif、Serif、MonoSpace可以选择&#xff0c;满足不了产品的需求&#xff0c;所以用想要定义成常用字体&#xff0c;主要是需要…

AGI时代的奠基石:Agent+算力+大模型是构建AI未来的三驾马车吗

★AI Agent&#xff1b;人工智能体&#xff0c;RPA&#xff1b;大语言模型&#xff1b;prompt&#xff1b;Copilot&#xff1b;AGI&#xff1b;ChatGPT&#xff1b;LLM&#xff1b;AIGC&#xff1b;CoT&#xff1b;Cortex&#xff1b;Genius&#xff1b;MetaGPT&#xff1b;大模…

借助ChatGPT撰写学术论文,如何设定有效的角色提示词指

大家好&#xff0c;感谢关注。这个给大家提供关于论文写作方面专业的讲解&#xff0c;以及借助ChatGPT等AI工具如何有效辅助的攻略技巧。有兴趣的朋友可以添加我&#xff08;yida985&#xff09;交流学术写作或ChatGPT等AI领域相关问题&#xff0c;多多交流&#xff0c;相互成就…

段页式管理

缝合怪&#xff01;&#xff01;&#xff01; 分页、分段的对比 分段分页段页式管理 先将进程按逻辑模块分段&#xff0c;再将各段分页 段页式管理的逻辑地址结构 段号页号页内偏移量 段号的位数&#xff1a;决定了每个进程最多可以分为几个段。 页号的位数&#xff1a;决定…

马斯克怒了,禁止员工使用苹果设备,抨击库克出卖数据给OpenA

昨晚&#xff0c;苹果发布会正式宣布了一系列重磅AI升级&#xff0c;甚至创造了一个新的概念——苹果智能&#xff08;Apple Intelligence&#xff09;。 这次升级在操作系统的交互层面上进行了智能化改进&#xff0c;使得更多自然语音和语言理解的控制成为可能&#xff0c;将…