代码随想录二刷复习 day1 704二分查找 27 移除元素 977 有序数组的平方

news/2024/12/2 20:31:48/

代码如下 

func search(nums []int, target int) int {

           left := 0 

           right := len(nums)-1

           for left <= right {

               middle := (left+right)/2

               if target < nums[middle] {  //因为上面的判断条件是left <= right,所以左右两个边界的值最后都能取到,而此时如果取 right = middle ,那么就会造成再次取到nums[middle]这个值,但是target < nums[middle]这个已经判断过了,所以要取   right = middle-1

                     right = middle-1

               }else if target > nums[middle]{

                    left = middle+1

               }else {

                   return middle

       

         } 

           return -1 

}

左闭右开区间 

func search(nums []int, target int) int {

           left := 0 

           right := len(nums)

           for left < right {

               middle := (left+right)/2

               if target < nums[middle] { //因为是左闭右开的区间所以是取不到右边界的值的,所以在初始右边界为 len(nums) 

                     right = middle

               }else if target > nums[middle]{

                    left = middle+1

               }else {

                   return middle

               }

           } 

           return -1 

}

               }

        小结 : left <= right 和 left < right 的区别 。举例 ,middle  = (left+right)/2 

如果是left <= right ,那么左和右可以取到4,4这样的区间,此时middle也为4,即middle 等于右边界 。如果是 left < right ,那么就取不到4,4这样的区间,只能取到4,5这个区间,此时middle值也为4.此时就取不到右边界  

27 移除元素 

代码如下 

func removeElement(nums []int, val int) int {

         slow := 0 

         for  fast := 0 ; fast < len(nums) ; fast++ { //遍历双指针,快指针负责遍历整个数组,慢指针负责收集删除元素后的数组元素 ,原则是如果与删除元素不相同的元素,放入慢指针指向的数组,慢指针向后移一位 

             if nums[fast] != val {

                 nums[slow] = nums[fast]

                 slow++

             }

         }

         return slow 

}

第一遍写的时候还想了一段时间,第二遍刷直接就写出来了。感觉自己的算法能力确实进步了一点。

977 有序数组的平方 

代码如下

思路: 定义一个结果数组,开始遍历原数组,因为原数组是非递减,所以平方后的最大值只会在两边产生,此时从左右两边依次遍历原数组,将左右两边的数的平方进行比较,并将平方和大的数放入新的数组中 

func sortedSquares(nums []int) []int {

             res := make([]int,len(nums))

             k := len(nums)-1

             left := 0 

             right := len(nums)-1 

             for left <= right {

                 if nums[left]*nums[left] < nums[right]*nums[right] {

                           res[k] = nums[right]*nums[right] 

                           

                           right-- 

                 }else {

                     res[k] = nums[left]*nums[left]

                    

                     left++

                 }

                 k--

             }

             return res 

}


http://www.ppmy.cn/news/59179.html

相关文章

基于探路者算法的极限学习机(ELM)回归预测-附代码

基于探路者算法的极限学习机(ELM)回归预测 文章目录 基于探路者算法的极限学习机(ELM)回归预测1.极限学习机原理概述2.ELM学习算法3.回归问题数据处理4.基于探路者算法优化的ELM5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;本文利用探路者算法对极限学习机进行优化&…

Java中的内存泄露、内存溢出与栈溢出

内存泄露、内存溢出与栈溢出 1、概述2、内存泄漏、内存溢出和栈溢出2.1、内存泄漏2.2、内存溢出2.3、栈溢出 2、总结 1、概述 大家好&#xff0c;我是欧阳方超。本次就Java中几个相似而又不同的概念做一下介绍。内存泄漏、内存溢出和栈溢出都是与内存相关的问题&#xff0c;但…

RabbitMQ 发布订阅模式,routing路由模式,topic模式

发布订阅模式 一个消息可以由多个消费者消费同一个消息 消费者1和2同时消费了该消息 举例 public static void main(String[] args) throws IOException, TimeoutException {//1 创建连接工厂ConnectionFactory connectionFactorynew ConnectionFactory();//2 设置rabbitmq …

pg 提升子链接源码分析

pg 上拉子链接源码分析 此分析基于 version 13.8&#xff0c; 在pg 中把子查询分为两类&#xff0c;一类是from 中的子查询&#xff1b; 一类是where 中的子查询&#xff0c;叫做子链接&#xff08;sublink&#xff09;。 下面用sublink&#xff08;子链接&#xff09;指代wh…

2023年第二十届五一数学建模竞赛题目 B题超详细思路

详细思路以及发布视频版&#xff0c;大家可以去观看&#xff0c;这里是对应的文字版&#xff0c;内容相差不多。 B题&#xff1a;快递需求分析问题 B题的问题难度不大&#xff0c;难点就在于后几问的模型求解。问题多、模型多、冗杂&#xff0c;就是B题的特点。 难度 A>B…

Flutter 组件抽取:日期(DatePicker)、时间(TimePicker)弹窗选择器【仿照】

简介 仿照《Flutter 仿ios自定义一个DatePicker》实行的日期弹窗选择器&#xff08;DatePicker&#xff09;、时间弹窗选择器&#xff08;TimePicker&#xff09; 效果 范例 class _TestPageState extends State<TestPage> {overridevoid initState() {super.initStat…

每日一题141——字符串中的最大奇数

给你一个字符串 num &#xff0c;表示一个大整数。请你在字符串 num 的所有 非空子字符串 中找出 值最大的奇数 &#xff0c;并以字符串形式返回。如果不存在奇数&#xff0c;则返回一个空字符串 "" 。 子字符串 是字符串中的一个连续的字符序列。 示例 1&#xff1…

MySQL索引概述

MySQL索引概述 当表中的数据量到达几十万甚至上百万的时候&#xff0c;SQL查询所花费的时间会很长&#xff0c;导致业务超时出错&#xff0c;此时就需要用索引来加速SQL查询。 由于索引也是需要存储成索引文件的&#xff0c;因此对索引的使用也会涉及磁盘I/O操作。如果索引创建…