代码随想录额外题目| 数组03 ●34排序数组查首尾位置 ●922按奇偶排序数组II●35搜索插入位置

#34排序数组查首尾位置

medium,我写的:1 暴力

vector<int> searchRange(vector<int>& nums, int target) {int start=-1;int end=-1;for(int i=0;i<nums.size();i++){if(nums[i]==target && start==-1) start=i;if(nums[i]==target && start>-1) end=i;}return {start,end};}

我写的,做了个类似二分搜索的方法:

vector<int> searchRange(vector<int>& nums, int target) {int start=0;int end=nums.size()-1;int res=-1;while(start<=end){//cout<<"start: "<<start<<", end: "<<end<<endl;int mid=(start+end)/2;if(nums[mid]==target){res=mid;break;}if(target<nums[mid]) end=mid-1;if(target>nums[mid]) start=mid+1;}//cout<<res<<endl;start=res; end=res;while(start>=0 && nums[start]==target){start--;}while(end<nums.size() && nums[end]==target){end++;}//if(nums.size()==1) return {0,0};if(res==-1) return{-1,-1};return {start+1,end-1};}

随想录:从两头都做类似二分搜索

     vector<int> searchRange(vector<int>& nums, int target) {int leftBorder = getLeftBorder(nums, target);int rightBorder = getRightBorder(nums, target);// 情况一if (leftBorder == -2 || rightBorder == -2) return {-1, -1};// 情况三if (rightBorder - leftBorder > 1) return {leftBorder + 1, rightBorder - 1};// 情况二return {-1, -1};}int getRightBorder(vector<int>& nums, int target) {int left = 0;int right = nums.size() - 1;int rightBorder = -2; // 记录一下rightBorder没有被赋值的情况while (left <= right) {int middle = left + ((right - left) / 2);if (nums[middle] > target) {right = middle - 1;} else { // 寻找右边界,nums[middle] == target的时候更新leftleft = middle + 1;rightBorder = left;}}return rightBorder;}int getLeftBorder(vector<int>& nums, int target) {int left = 0;int right = nums.size() - 1;int leftBorder = -2; // 记录一下leftBorder没有被赋值的情况while (left <= right) {int middle = left + ((right - left) / 2);if (nums[middle] >= target) { // 寻找左边界right = middle - 1;leftBorder = right;} else {left = middle + 1;}}return leftBorder;}

#922 按奇偶排序数组II

我的解法,有点蠢:

vector<int> sortArrayByParityII(vector<int>& nums) {int cnt=0;vector<int> odd;vector<int> even;for(int i=0;i<nums.size();i++){if(i%2!=0 && nums[i]%2==0) odd.push_back(i);if (i%2==0 && nums[i]%2!=0) even.push_back(i);}for(int i=0;i<odd.size();i++){swap(nums[odd[i]],nums[even[i]]);}return nums;}

inplace解法: 把odd idx放的偶数,给换到even idx放的奇数

注意j是从1开始,而且每轮i,j都是继续增加不回去

空间表现很好,但时间表现很一般

vector<int> sortArrayByParityII(vector<int>& nums) {int j=1;for(int i=0;i<nums.size();i+=2){if(nums[i]%2){while(j<nums.size() && nums[j]%2) j+=2;swap(nums[i],nums[j]);}}return nums;}

#35搜索插入位置 

要求复杂度O log n ,我写的:

int searchInsert(vector<int>& nums, int target) {int start=0;int end=nums.size()-1;while(start<=end){int mid=(start+end)/2;//cout<<"mid: "<<mid<<endl;if(nums[mid]==target) return mid;else if(mid==start) {if(start+1<nums.size() && target>nums[start+1]) return start+2;return target>nums[start]?start+1:start;}     if(nums[mid]>target) end=mid-1;if(nums[mid]<target) start=mid+1;}return -1;}

随想录写的:所有情况都能统一变成return end+1或者return start

int searchInsert(vector<int>& nums, int target) {int start=0;int end=nums.size()-1;int mid;while(start<=end){mid=(start+end)/2;if(nums[mid]==target) return mid;if(nums[mid]>target) end=mid-1;if(nums[mid]<target) start=mid+1;}return end+1;}

这里没想明白为什么不对,有空想想

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

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

相关文章

【Docker 学习笔记】Windows Docker Desktop 安装

文章目录 一、前言二、Windows Docker 安装1. 基于Hyper-V后端和Windows容器的安装2. 基于WSL2后端的安装&#xff08;推荐&#xff09;3. 安装Docker Desktop on Windows4. 启动并验证Docker Desktop 一、前言 Docker并非是一个通用的容器工具&#xff0c;它依赖于已存在并运…

Redis学习路线(4)—— Redis实现项目缓存

一、什么是缓存 &#xff08;一&#xff09;概念&#xff1a;缓存就是数据交换的缓冲区&#xff08;称为Cache&#xff09;&#xff0c;是存储数据的临时区域&#xff0c;一般读写性能较高。 &#xff08;二&#xff09;常见缓存&#xff1a; 浏览器缓存&#xff0c;服务器缓…

SpringBootAdmin介绍

一、SpringBootAdmin 简介 1.1 概述 SpringBootAdmin 是一个非常好用的监控和管理的开源组件&#xff0c;该组件能够将 Actuator 中的信息进行界面化的展示&#xff0c;也可以监控所有 Spring Boot 应用的健康状况&#xff0c;提供实时警报功能。 1.2 功能特性 显示应用程序…

智能家居是否可与ChatGPT深度融合?

​ ChatGPT自2022年面世以来&#xff0c;已为亿万网民提供智能问答服务。然而我们是否曾想到&#xff0c;这一人工智能驱动的聊天机器人&#xff0c;是否可为智能家居赋能? 要实现ChatGPT与智能家居设备之间的无缝对话&#xff0c;单单依靠一台终端是远远不够的。ChatGPT必须…

Mybatis中where 1=1 浅析

在一些集成mybatis的工程中经常看到where11 的代码&#xff0c;也有同事问我&#xff0c;这样写有什么用&#xff0c;下面对其进行简单的分析记录一下。 1、场景 看下面这样一段xml中的代码 <select id"queryBook" parameterType"com.platform.entity.Book…

ST官方基于米尔STM32MP135开发板培训课程(一)

本文将以Myirtech的MYD-YF13X以及STM32MP135F-DK为例&#xff0c;讲解如何使用STM32CubeMX结合Developer package实现最小系统启动。 1.开发准备 1.1 Developer package准备 a.Developer package下载&#xff1a; ‍https://www.st.com/en/embedded-software/stm32mp1dev.ht…

使用powershell找回丢失的RDCManage密码

内网的一台服务器上的装机默认用户密码忘记了&#xff0c;但是好在别的电脑上使用RDCMan&#xff08;Remote Desktop Connection Manager&#xff09;连接过这台服务器&#xff0c;并且保存了密码。于是经过一番折腾&#xff0c;最后把密码找回来了&#xff1a; 最后成功的powe…

个人建议(2023-7-31)【建议】

前言 2023-7-31 21:54:54 我的个人建议又㕛叒叕来了 关键重点黑体标出 本文已在CSDN博客中发布文章 本文已在CSDN建议社区中发布帖子 最近比较忙只能简单写一写 收货地址&#xff0c;浏览之后再确认&#xff0c;老是怕提交错误 快递进度查询 草稿也能设置专栏 不用重新…

同步锁: synchronized

synchronized 1. synchronized的特性2. synchronized的使用3. synchronized的锁机制 1. synchronized的特性 原子性: 所谓原子性就是指一个操作或者多个操作&#xff0c;要么全部执行并且执行的过程不会被任何因素打断&#xff0c;要么就都不执行。可见性: 可见性是指多个线程…

IO流简述

IO流IO流使用场景 什么是IO流常用的IO流字节流字符流缓冲流 BIO、NIO、AIO的区别 IO流 IO流使用场景 如果操作的是纯文本文件&#xff0c;优先使用字符流如果操作的是图片、视频、音频等二进制文件。优先使用字节流如果不确定文件类型&#xff0c;优先使用字节流。字节流是万能…

如何使用Flask-SQLAlchemy来管理数据库连接和操作数据?

首先&#xff0c;我们需要安装Flask-SQLAlchemy。你可以使用pip来安装它&#xff0c;就像这样&#xff1a; pip install Flask-SQLAlchemy好了&#xff0c;现在我们已经有了一个可以操作数据库的工具&#xff0c;接下来让我们来看看如何使用它吧&#xff01; 首先&#xff0c…

前端接收后端返回换行符 /n 不生效

问题&#xff1a;前端接收后端返回换行符 /n 不换行、不生效 解决方案&#xff1a; 一、 设置css的white-space属性 <div class"text-container">{{ text }}</div>export default {data() {return {text: 这是第一行\n这是第二行,};}, };<style sco…

php-golang-rpc 简单的jsonrpc实践

golang代码&#xff1a; package main import ( "net" "net/rpc" "net/rpc/jsonrpc" ) type App struct{} type Res struct { Code int json:"code" Msg string json:"msg" Data any json:"data" } fun…

Qu‘est-ce Que C‘est? 2023牛客暑期多校训练营4-J

登录—专业IT笔试面试备考平台_牛客网 题目大意&#xff1a;求满足如下条件的长度为n的数组数量&#xff1a;所有数字的范围在-m~m之间&#xff0c;任意连续的元素数量>1的区间的的区间和>0 1<n,m<5000; 思路&#xff1a;要让所有区间元素和>0&#xff0c; 我…

上门居家养老小程序社区养老小程序开发方案详解

居家养老管理社区养老小程序有哪些功能呢&#xff1f; 1.选择养老服务类型 医疗护理&#xff0c;家政服务预约&#xff0c;上门助浴、上门做饭&#xff0c;上门助餐&#xff0c;生活照护&#xff0c;康复理疗、精神慰藉、委托代办等。各项服务的详情介绍。 2.选择预约时间 选择…

【RabbitMQ】之持久化机制

目录 一、RabbitMQ 持久化机制 1、RabbitMQ 持久化概述2、队列持久化3、消息持久化4、交换器持久化 二、RabbitMQ 知识扩展 1、内存告警与内存换页2、磁盘告警与配置3、数据写入磁盘时机4、磁盘消息格式5、磁盘文件删除机制 一、RabbitMQ 持久化机制 1、RabbitMQ 持久化概述…

2023-07-31:用r、e、d三种字符,拼出一个回文子串数量等于x的字符串。 1 <= x <= 10^5。 来自百度。

2023-07-31&#xff1a;用r、e、d三种字符&#xff0c;拼出一个回文子串数量等于x的字符串。 1 < x < 10^5。 来自百度。 答案2023-07-31&#xff1a; 大体步骤如下&#xff1a; 1.初始化一个字符串builder&#xff0c;用于构建结果字符串。 2.初始化一个字符变量c…

剑指offer10-I.斐波那契数列

学计算机的对这道题肯定不陌生&#xff0c;我记得是学C语言的时候学递归的时候有这道题&#xff0c;于是我就世界用递归写了如下代码&#xff1a; class Solution {public int fib(int n) {if(n1) return 1;if(n0) return 0;return (fib(n-1) fib(n-2)) % 1000000007;} } 到…

ubuntu22.0安装Barrier局域网共享鼠标键盘

ubuntu22.0安装Barrier局域网共享鼠标键盘 参考网站安装步骤客户端一直开启中解决 参考网站 https://idroot.us/install-barrier-ubuntu-22-04/ 安装步骤 sudo apt update sudo apt upgrade sudo apt install wget apt-transport-https gnupg2 software-properties-common s…

rdb和aof

RDB持久化&#xff1a;原理是将Redis在内存中的数据库记录定时dump到磁盘上的RDB持久化AOF持久化&#xff1a;原理是将Redis的操作日志以追加的方式写入文件 rdb&#xff1a; 开启方式&#xff1a;客户端可以通过向Redis服务器发送save或bgsave命令让服务器生成rdb文件&#…