【进击的算法】基础算法——怎么优雅地控制边界范围

news2025/1/11 14:25:48
  • 学习范围 : ✔️数组 ✔️边界控制
  • 本文作者 : 蓝色学者i

边界控制的艺术

  • 前言
  • 一、为什么需要控制边界?
  • 二、怎么优雅地控制边界?
  • 三、令人抓狂的二分查找
    • 3.1 题目概述
    • 3.2解题思路
    • 3.3 解决方案
      • 方案一:边界都有效
      • 方案二:有一个边界无效
    • 3.4参考代码
    • 3.5 总结
  • 四、螺旋矩阵
    • 题目概述
    • 思路提示
    • 参考代码
  • 五、结语

前言

大家好久不见,今天想跟大家分享如何优雅地控制边界,边界的控制不是算法,更像是一门艺术,优秀的程序员能够优雅地控制边界,要成为一名优秀的程序员,我们就要去学习如何控制边界~

一、为什么需要控制边界?

国有国界,家有家规,贸然地使用不属于自己的东西,是一件很危险的事情~,因此我们需要合理地控制边界!不然你很容易看到以下报错 ~

IndexOutOfBoundsException(JAVA)
Segmentation Fault(LINUX)

二、怎么优雅地控制边界?

回答这个问题前,我想问大家一个问题:让大家给一个班级分组,你会如何分?

  • 方案一 :按照固定人数来分
  • 方案二 :随意分,按照心情来分

为了方便以后的管理,我想你一定会选择方案一的~


那如何优雅地控制边界呢?

重要
统一管理方案,是优雅控制边界的重要方法!

三、令人抓狂的二分查找

3.1 题目概述

二分查找相信大家并不陌生,虽然原理很简单,但我们在手撕代码的时候就会出现各种各样的小问题,当你好不容易解决掉这些问题,却也一直在发懵,下次见到依然是发懵的状态,其实这就是边界没有搞清的原因。
再来读一下题:

  • 点击做题:leetcode 二分查找

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

3.2解题思路

二分查找的逻辑比较简单:在一个有序数组里,拿我们的目标值与target(目标值)与 mid 对应的值进行比较,根据比较的值,直接将区间缩小一半,直到找到那个数为止

在这里插入图片描述
其实这样说是很不负责任的,什么时候停止?是left > right 还是left >= right ?

重要
有一个统一的标准很重要

这个统一的标准到底是啥呢,有两种方案可以选择:

  • 边界自始至终都是有效的,left和right都是有意义的
  • 左边界有意义,右边界无意义,或左边界无意义,右边界有意义

3.3 解决方案

方案一:边界都有效

如果左值left和右值right都有意义,那么我们在比较完mid和target之后,为保证新的left和right都有意义,对应要变换的边界就要跳过mid,如图:
在这里插入图片描述

int right = numsSize - 1;//保证区间都是有效的 
while(left >= right)//既然有效就要二分查找
{
	    int mid = (left + right)/2;
        if(target == nums[mid])   return mid;
        
        //两次修正都要保证新的区间仍然有效
        if(target < nums[mid])    
            right = mid-1;    
        else        
            left = mid+1;        
}

方案二:有一个边界无效

如图,在最开始我们就让某一个区间无效,由于右区间较简单,因此采用右边界无效的方案

我们希望下一次缩小区间的时候,仍然是右区间无效,经过上一次mid与target比较后,我们已经清楚mid不是我们要找的,因此下一次调整区间,我们就可以让right直接到mid位置处,这样右区间仍然没有意义!
在这里插入图片描述

int right = numsSize;//保证右区间是无效的 
while(left > right)//等于是无效区间,不需要二分查找
{
	    int mid = (left + right)/2;
        if(target == nums[mid])   return mid;
        
        //两次修正都要保证新的区间仍然有效
        if(target < nums[mid])    
            right = mid;//保证新区间仍然是无效区间    
        else        
            left = mid+1;        
}

3.4参考代码

//方案一
int search(int* nums, int numsSize, int target){
    int left = 0;
    int right = numsSize-1;
    //int mid = 0;

    while(left <= right)
    {
        int mid = (left + right)/2;
        if(target == nums[mid])
        {
            return mid;
        }

        if(target < nums[mid])
        {
            right = mid-1;
        }
        else
        {
            left = mid+1;
        }
    }

    return -1;
}
//方案二
int search(int* nums, int numsSize, int target){
    int left = 0;
    int right = numsSize;


    while(left < right)
    {
        int mid = (left + right)/2;
        if(target == nums[mid])
        {
            return mid;
        }

        if(target < nums[mid])
        {
            right = mid;
        }
        else
        {
            left = mid+1;
        }
    }

    return -1;
}

3.5 总结

二分查找问题虽然较为简单,但对边界问题有着比较严格的要求,只有学会控制边界,才不会出现一些细节的错误,虽然二分查找的思维很简单,但细节决定成败,相信看到这里,你一定有所体悟

四、螺旋矩阵

讲解完二分查找,相信你对边界问题掌握的更好了,接下来你可以去挑战一下略有难度的螺旋矩阵了!

题目概述

  • 点击做题:螺旋矩阵2

给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。
在这里插入图片描述

思路提示

同样的,我们要记住统一管理方案的原则,比如有四条边控制,我们应该怎么控制?
在这里插入图片描述
如图,第一行我们就只控制前三个,并且每一行或列都按照这个标准进行赋值,这样我们的边界就很难控制乱,第一行完成后,我们再去控制第二行,按照这样的标准一点点赋值

参考代码

int** generateMatrix(int n, int* returnSize, int** returnColumnSizes){

    *returnSize = n;
    *returnColumnSizes = (int*)malloc(sizeof(int) * n);

    int** result = (int**)malloc(sizeof(int*) * n);
    int i,j;
    for(i = 0; i < n; i++) {
        result[i] = (int*)malloc(sizeof(int) * n);
        (*returnColumnSizes)[i] = n;
    }

    int k = 1;
    int mid = n / 2;
    int startx = 0;
    int starty = 0;
    int offset = 1;
 
    int fre = n / 2;//一共要处理几层
    while(fre--)
    {       
        for(j = starty;j<n-offset;j++)
            result[startx][j] = k++;
        
        for(i = startx;i<n-offset;i++)
            result[i][j] = k++;
        
        for(;j>startx;j--)
            result[i][j] = k++;
        
        for(;i>starty;i--)
            result[i][j] = k++;
        
        startx++;
        starty++;
        offset++;
    }
   
    *returnSize = n;
    for(int i = 0;i<n;i++)
    {
        (*returnColumnSizes)[i] = n;
    }
   
   //单独判断是否为奇数个
    if(n%2){
        result[mid][mid] = k;
    }
    
    return result;
}

五、结语

到这里,今天的内容就全部结束了,生活中,人与人也有存有界限感,程序编写依然如此,如果感觉今天有所收获,可以给学者一个关注,我们下次再见~

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

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

相关文章

Python3 循环语句

本章节将为大家介绍 Python 循环语句的使用。 Python 中的循环语句有 for 和 while。 Python 循环语句的控制结构图如下所示&#xff1a; while 循环 Python 中 while 语句的一般形式&#xff1a; while 判断条件(condition)&#xff1a;执行语句(statements)…… 执行流程…

【数据结构之二叉树系列】万字深剖普通二叉树的遍历+分治算法思想

目录前言一、背景知识二、前序遍历三、中序遍历四、后序遍历五、求二叉树中结点的个数1. 遍历计数&#xff08;1&#xff09;前序遍历计数&#xff08;2&#xff09;中序遍历计数&#xff08;3&#xff09;后序遍历计数2.分治算法思想&#xff08;推荐&#xff09;敬请期待前言…

Java基础 IO

IO流 IO流 什么是IO流&#xff1f; 存储和读取数据的解决方案 I&#xff1a;input O&#xff1a;output 流&#xff1a;像水流一样传输数据 IO流的作用&#xff1f; 用于读写数据&#xff08;本地文件&#xff0c;网络&#xff09; IO流按照流向可以分类哪两种流&#xff1f…

数据库02_函数依赖,数据库范式,SQL语句关键字,数据库新技术---软考高级系统架构师009

1.首先我们来看这个,给定一个X,能确定一个Y那么就说,X确定Y,或者Y依赖x,那么 比如y = x * x 就是x确定y,或者y依赖于x 2.然后再来看图,那么左边的部分函数依赖,就是,通过A和B能决定C,那么如果A只用给就能决定C,那么就是部分函数依赖. 3.然后再来看,可以看到,A可以决定B,那么…

servlet过滤器Filter简要回顾-过滤请求字符编码,/和/*和/**的区别

servlet过滤器Filter简要回顾-过滤请求字符编码,/和/*和/**的区别servlet过滤器1.filter过滤器的含义2.filter过滤器的使用3.测试-过滤字符编码正确响应中文编码3.1 创建servlet用于显示中文字符3.2 自定义过滤器3.3 配置web.xml中的servlet映射以及过滤器请求拦截3.4 运行输出…

【编程入门】开源记事本(安卓版)

背景 前面已输出多个系列&#xff1a; 《十余种编程语言做个计算器》 《十余种编程语言写2048小游戏》 《17种编程语言10种排序算法》 《十余种编程语言写博客系统》 《十余种编程语言写云笔记》 本系列对比云笔记&#xff0c;将更为简化&#xff0c;去掉了网络调用&#xff0…

第二章 物理层

第二章 物理层 2.1 物理层的基本概念 物理层考虑的是怎样才能在连接各种就算机的传输媒体上传输数据比特流&#xff0c;而不是指具体的传输媒体 物理层的主要任务描述为确定与传输媒体的接口有关的一些特性 机械特性 指明接口所用接线器的形状和尺寸&#xff0c;引脚数目和排…

辗转相除以及辗转相减法

文章目录前言辗转相除法&#xff08;又名欧几里算法&#xff09;辗转相减法&#xff08;又名更相减损法&#xff09;原始辗转相减法改版辗转相减法&#xff08;减的是指数&#xff09;参考文章前言 在学习Acwing c蓝桥杯辅导课第八讲数论-AcWing 1223. 最大比例时有使用到求指…

使用CNN进行2D路径规划

卷积神经网络(CNN)是解决图像分类、分割、目标检测等任务的流行模型。本文将CNN应用于解决简单的二维路径规划问题。主要使用Python, PyTorch, NumPy和OpenCV。 任务 简单地说&#xff0c;给定一个网格图&#xff0c;二维路径规划就是寻找从给定起点到所需目标位置&#xff0…

如何取消PDF文件的保护设置?

PDF文件可以设置两种保护模式&#xff0c;一种是打开文件保护&#xff0c;也就是设置打开密码&#xff0c;只有输入密码才能打开文件&#xff1b;另一种是限制保护&#xff0c;即限制密码&#xff0c;可以根据需要设置PDF文件是否可以进行编辑、复制、打印等操作。 如果不需要…

第二篇:Haploview做单倍型教程2--分析教程

大家好&#xff0c;我是邓飞&#xff0c;这里介绍一下如何使用Haploview进行单倍型的分析。 计划分为三篇文章&#xff1a; 第一篇&#xff1a;Haploview做单倍型教程1–软件安装第二篇&#xff1a;Haploview做单倍型教程2–分析教程第三篇&#xff1a;Haploview做单倍型教程…

kaggle竞赛 | 计算机视觉 | Doodle Recognition Challenge

目录赛题链接赛题背景数据集探索合并多个类别CSV数据集数据建模 (pytorch)赛题链接 https://www.kaggle.com/competitions/quickdraw-doodle-recognition/overview/evaluation 数据集从上述链接中找 赛题背景 Quick&#xff0c;Draw&#xff01;作为实验性游戏发布&#xff…

python元组

python元组 文章目录python元组一、实验目的二、实验原理三、实验环境四、实验内容五、实验步骤1.创建元组2.访问元组3.修改元组4.删除元组5.索引及截取6.元组运算符7.内置函数总结一、实验目的 掌握元组的用法 二、实验原理 Python 的元组与列表类似&#xff0c;不同之处在…

2. MySQL之mysql-connector-python的安装使用

MySQL 是最流行的关系型数据库管理系统&#xff0c;关于数据库以及MySQL相关知识&#xff0c;此处不再赘述。本篇介绍使用 mysql-connector-python 来连接使用 MySQL。 1. 安装mysql-connector-python 执行以下代码&#xff0c;没有报错&#xff0c;证明安装成功。 import my…

旗舰版:Stimulsoft Ultimate 2023.1.5 Crack

Stimulsoft Ultimate 是一套用于创建报告和仪表板的通用工具。该产品包括一整套适用于 WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java 和其他环境的工具。 无需比较产品功能。Stimulsoft Ultimate 包括一切&#xff01; 报表设计器的一切 我们提供易于使用且功能齐…

Android深入系统完全讲解(41)

我们要学习的是整体逻辑&#xff0c;我们 C 找 Java 的依据是类和对象&#xff0c;参数中 JNIEnv *env, jobject obj 。 env 代表当前环境上下文&#xff0c;这个当我们多个线程调用的时候&#xff0c;需要 AttachCurrentThread 进行设定&#xff0c;让 env 关联到当前线程&…

Linux常见命令 24 - RPM命名管理-包命名与依赖性

目录 1. RPM包命名规则 2. RPM包依赖性 1. RPM包命名规则 如包全名&#xff1a;httpd-2.2.15-15.e16.centos.1.i686.rpm httpd&#xff1a;软件包名2.2.15&#xff1a;软件版本15&#xff1a;软件发布的次数el6.centos&#xff1a;适合的Linux平台&#xff1a;CentOS 6.xi6…

springboot和nacos整合mybatis-plus实现多数据源管理

文章目录1.依赖2.配置文件3.redis测试3.1redis配置文件3.2controller3.3测试4.mysql测试4.1数据库表和结构4.2实体类和枚举4.3DogMapper.xml4.4DogMapper4.5service和serviceImpl4.6controller4.7测试写了一个小demo&#xff0c;通过mybatis-plus实现多数据源管理使用了mysql和…

【笔记】A simple yet effective baseline for 3d human pose estimation

【论文】https://arxiv.org/abs/1705.03098v2 【pytorch】(本文代码参考)weigq/3d_pose_baseline_pytorch: A simple baseline for 3d human pose estimation in PyTorch. (github.com) 【tensorflow】https://github.com/una-dinosauria/3d-pose-baseline 基本上算作是2d人体…

Python压缩JS文件,PythonWeb程序员必看系列,重点是 slimit

Python 压缩文件系列文章&#xff0c;我们已经完成了 2 篇&#xff0c;具体如下&#xff1a; Python Flask 实现 HTML 文件压缩&#xff0c;9 级压缩 Python 压缩 css 文件&#xff0c;第三方模块推荐 压缩JS学习目录&#x1f6a9; jsmin 库&#x1f3a8; 库的安装&#x1f3a8…