牛客NC209 最短无序连续子数组【中等 数组,双指针 C++/Java/Go/PHP】

news2024/11/20 9:49:07

题目

在这里插入图片描述
题目链接:
https://www.nowcoder.com/practice/d17f4abd1d114617b51e951027be312e

思路

解题思路
1、方法1,排序对比:将数组按升序排序,然后与原数组对照,
         从哪里开始变化到哪里结束变化的数组就是答案。
2、 方法2,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到,
下面的答案里注释处提供了该代码

参考答案C++

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param nums int整型vector
     * @return int整型
     */
    int findUnsortedSubarray(vector<int>& nums) {
        /*
          二、解题思路
          1、方法,排序对比:将数组按升序排序,然后与原数组对照,
             从哪里开始变化到哪里结束变化的数组就是答案。
          2、 方法,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到
        */

        int n = nums.size();
        vector<int> bak(n);
        for (int k = 0; k < n; k++) {
            bak[k] = nums[k];
        }
        int left = -1;
        int right = -1;
        sort(nums.begin(), nums.end());
        for (int i = 0; i < n; i++) {
            if (left == -1 && nums[i] != bak[i]) {
                left = i;
            }
            if (right == -1 && nums[n - i - 1] != bak[n - i - 1]) {
                right = n - i - 1;
            }
        }

        if ( right == -1 ) {
            return 0;
        } else {
            return right - left + 1;
        }

        /*
                 2、 方法,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到
                    //双指针
                    //我们实际上需要找到的边界就是从左往右,找到比左边最大值还小的最右下标,
                    //从右往左,找到比右边最小值还大的最左下标。
                    //https://www.cnblogs.com/xqmeng/p/15093340.html
                class Solution {
                public:
                    int findUnsortedSubarray(vector<int>& nums) {
                        int n = nums.size();
                        int maxn = INT_MIN, right = -1;
                        int minn = INT_MAX, left = -1;
                        for (int i = 0; i < n; i++) {
                            if (maxn > nums[i]) {
                                right = i;
                            } else {
                                maxn = nums[i];
                            }
                            if (minn < nums[n - i - 1]) {
                                left = n - i - 1;
                            } else {
                                minn = nums[n - i - 1];
                            }
                        }
                        return right == -1 ? 0 : right - left + 1;
                    }
                };
        */
    }
};

参考答案Java

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param nums int整型一维数组
     * @return int整型
     */
    public int findUnsortedSubarray (int[] nums) {
        int n = nums.length;
        int[] bak = new int[n];
        for (int i = 0; i < n ; i++) {
            bak[i] = nums[i];
        }

        Arrays.sort(nums);
        int left = -1, right = -1;
        for (int i = 0; i < n ; i++) {
            if (left == -1 && nums[i] != bak[i]) {
                left = i;
            }

            if (right == -1 && nums[n - i - 1] != bak[n - i - 1]) {
                right = n - i - 1;
            }
        }

        return right == -1 ? 0 : right - left + 1;
    }


    public int f2(int[]
                  nums) { //别人的代码,最优解。时间复杂度O(n),空间复杂度O(1)。但很难想到
        //双指针
        //我们实际上需要找到的边界就是从左往右,找到比左边最大值还小的最右下标,
        //从右往左,找到比右边最小值还大的最左下标。
        //https://www.cnblogs.com/xqmeng/p/15093340.html
        int n = nums.length;
        int maxn = 0x80000000, right = -1;
        int minn = 0x7fffffff, left = -1;
        for (int i = 0; i < n; i++) {
            if (maxn > nums[i]) {
                right = i;
            } else {
                maxn = nums[i];
            }

            if (minn < nums[n - i - 1]) {
                left = n - i - 1;
            } else {
                minn = nums[n - i - 1];
            }
            //System.out.println(i+":  left="+left+",right="+right+" maxn="+maxn+",minn="+minn);
        }

        return right == -1 ? 0 : right - left + 1;
    }
}

参考答案Go

package main

import "sort"

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param nums int整型一维数组
 * @return int整型
 */
func findUnsortedSubarray(nums []int) int {
	/*
	   二、解题思路
	   1、方法,排序对比:将数组按升序排序,然后与原数组对照,
	      从哪里开始变化到哪里结束变化的数组就是答案。
	   2、 方法,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到
	*/

	n := len(nums)
	bak := make([]int, n)
	for k, v := range nums {
		bak[k] = v
	}
	left := -1
	right := -1
	sort.Ints(nums)
	for i := 0; i < n; i++ {
		if left == -1 && nums[i] != bak[i] {
			left = i
		}
		if right == -1 && nums[n-i-1] != bak[n-i-1] {
			right = n - i - 1
		}
	}

	if right == -1 {
		return 0
	} else {
		return right - left + 1
	}

	/*
			 2、 方法,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到
				//双指针
		        //我们实际上需要找到的边界就是从左往右,找到比左边最大值还小的最右下标,
		        //从右往左,找到比右边最小值还大的最左下标。
				//https://www.cnblogs.com/xqmeng/p/15093340.html
			class Solution {
			public:
			    int findUnsortedSubarray(vector<int>& nums) {
			        int n = nums.size();
			        int maxn = INT_MIN, right = -1;
			        int minn = INT_MAX, left = -1;
			        for (int i = 0; i < n; i++) {
			            if (maxn > nums[i]) {
			                right = i;
			            } else {
			                maxn = nums[i];
			            }
			            if (minn < nums[n - i - 1]) {
			                left = n - i - 1;
			            } else {
			                minn = nums[n - i - 1];
			            }
			        }
			        return right == -1 ? 0 : right - left + 1;
			    }
			};
	*/
}

参考答案PHP

<?php


/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param nums int整型一维数组 
 * @return int整型
 */
function findUnsortedSubarray( $nums )
{
    /*
    二、解题思路
    1、方法,排序对比:将数组按升序排序,然后与原数组对照,
       从哪里开始变化到哪里结束变化的数组就是答案。
    2、 方法,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到
 */
    $bak = [];
    foreach ($nums as $k=>$v){
        $bak[$k] = $v;
    }

    sort($nums);

    $left =-1;
    $right =-1;

    for($i=0;$i<count($nums);$i++){
        if($left ==-1 && $nums[$i]!=$bak[$i]){
            $left = $i;
        }

        if($right ==-1 &&$nums[count($nums)-$i-1] !=$bak[count($bak)-$i-1]){
            $right = count($nums)-$i-1;
        }
    }
    if($right ==-1){
        return 0;
    }else{
        return $right -$left+1;
    }

	/*
			 2、 方法,别人的代码:效率更高,时间复杂度O(n),空间复杂度O(1)。但很难想到
				//双指针
		        //我们实际上需要找到的边界就是从左往右,找到比左边最大值还小的最右下标,
		        //从右往左,找到比右边最小值还大的最左下标。
	            //https://www.cnblogs.com/xqmeng/p/15093340.html
			class Solution {
			public:
			    int findUnsortedSubarray(vector<int>& nums) {
			        int n = nums.size();
			        int maxn = INT_MIN, right = -1;
			        int minn = INT_MAX, left = -1;
			        for (int i = 0; i < n; i++) {
			            if (maxn > nums[i]) {
			                right = i;
			            } else {
			                maxn = nums[i];
			            }
			            if (minn < nums[n - i - 1]) {
			                left = n - i - 1;
			            } else {
			                minn = nums[n - i - 1];
			            }
			        }
			        return right == -1 ? 0 : right - left + 1;
			    }
			};
	*/
}

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

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

相关文章

初识 Express

目录 1. Express 简介 1.1. 什么是 Express 1.1.1. 概念 1.1.2. 通俗理解 1.1.3. Express 的本质 1.2. 进一步理解 Express 1.2.1. 问题引入1——不使用 Express 能否创建 Web 服务器&#xff1f; 1.2.2. 问题引入2——有了 http 内置模块&#xff0c;为什么还要用 Exp…

【算法刷题 | 贪心算法03】4.25(最大子数组和、买卖股票的最佳时机|| )

文章目录 4.最大子数组和4.1题目4.2解法一&#xff1a;暴力4.2.1暴力思路4.2.2代码实现 4.3解法二&#xff1a;贪心4.3.1贪心思路4.3.2代码实现 5.买卖股票的最佳时机||5.1题目5.2解法&#xff1a;贪心5.2.1贪心思路5.2.2代码实现 4.最大子数组和 4.1题目 给你一个整数数组 n…

【JavaScript】内置对象 ③ ( Math 内置对象 | Math 内置对象简介 | Math 内置对象的使用 )

文章目录 一、Math 内置对象1、Math 内置对象简介2、Math 内置对象的使用 二、代码示例1、代码示例 - Math 内置对象的使用2、代码示例 - 封装 Math 内置对象 一、Math 内置对象 1、Math 内置对象简介 JavaScript 中的 Math 内置对象 是一个 全局对象 , 该对象 提供了 常用的 数…

openEuler-22.03下载、安装

一、下载 下载地址&#xff1a;openEuler下载 | 欧拉系统ISO镜像 | openEuler社区官网 下载版本&#xff1a;openEuler-22.03-LTS-x86_64-dvd.iso 二、安装 配置完后开启虚拟机 设置完后&#xff0c;重启虚拟机 设置桥接模式的网络 cd /etc/sysconfig/network-scripts/ vi if…

Apple公司面试题之Apple-Orange

1. 引言 你幻想过在Apple公司工作吗&#xff1f; 如果心动过&#xff0c;那这个逻辑推理面试题就是给你准备的&#xff01;这是一道有趣的面试题&#xff0c;如下所示&#xff1a; 看到这里的同学&#xff0c;我建议你暂停文章&#xff0c;拿起笔和纸&#xff0c;试一试。准…

图像在神经网络中的预处理与后处理的原理和作用(最详细版本)

1. 问题引出及内容介绍 相信大家在学习与图像任务相关的神经网络时&#xff0c;经常会见到这样一个预处理方式。 self.to_tensor_norm transforms.Compose([transforms.ToTensor(), transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))]) 具体原理及作用稍后解释&…

用html写一个旋转菜单

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>旋转菜单</title><link relstylesheet href"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.css"&…

重发布的原理及其应用

重发布的作用&#xff1a; 在一个网络中&#xff0c;若运行多种路由协议或者相同协议的不同进程&#xff1b;因为协议之间不能直接沟通计算&#xff0c;进程之间也是独立进行转发和运算的&#xff0c;所以&#xff0c;需要使用重发布来实现路由的共享。 条件 &#xff1a; 1&am…

保护数据安全:加密算法知多少,几种常见的加密算法及其应用

在当今数字化时代&#xff0c;数据安全是一个非常重要且不可忽视的问题。为了保护敏感数据不被恶意窃取或篡改&#xff0c;加密算法诞生了。加密算法通过对原始数据转换和处理成不可读取的内容&#xff0c;防止未经授权的人读取和理解&#xff0c;从而确保数据的安全性、机密性…

熟悉mybatis操作全过程(详细操作)

目录 操作前准备 创建实体类 Brand 准备测试用例 安装mybatisx插件 查询 查询所有数据 结果映射 实现查看详情逻辑功能 条件查询 多条件动态条件查询 单条件动态查询 添加 基本添加功能 主键返回 修改数据 修改全部字段 修改动态字段 删除数据 删除一个…

GRASSHOPPER电池Expression

Grasshopper中如果要实现简单的条件if语句的效果&#xff0c;可以使用电池Expression。 举例&#xff1a;获取两个数的差值&#xff0c;永远用大数减去小数

js网络请求---fetch和XMLHttpRequest的用法

fetch 语法规则 let promise fetch(url, [options]) //url —— 字符串&#xff1a;要访问的 URL。 //options —— 对象&#xff1a;可选参数&#xff1a;method&#xff0c;header 等。 fetch函数返回一个promise&#xff0c;若存在网络问题&#xff0c;或网址不存在&…

【linux】基础IO(软硬链接)

上一节我们已经搞懂了已经被打开的文件&#xff0c;还有没有被打开的文件都是怎样被管理起来的&#xff0c;同样&#xff0c;路径的重要性也不言而喻&#xff0c;是确定文件在那个分区&#xff0c;进而可以解析到目标文件与目录内容的关系&#xff0c;从而找到inode&#xff0c…

MATLAB线性函数拟合并预测

线性函数拟合&#xff0c;由线性函数很好描述的一个数集,也就是说如果我们所考虑的数据是以y(x)的形式给出&#xff0c;并且其中f(x)满足: 要求得 m 和b的值&#xff0c;我们可以使用一个称为 polyii(x,y,n)的 MATLAB 函数&#xff0c;其中n是我们要 MATLAB 求出的多项式的次数…

ubuntu18.04系统编译openwrt21.02.3

搭建ubuntu18.04环境 使用虚拟机安装ubuntu环境网上教程很多&#xff0c;这里不做赘述&#xff0c;主要是安装一些我们在编译openwrt时可能会用到的一些工具环境 sudo apt-get update sudo apt instll libncurses-dev gawk sudo apt-get install build-essential libncurses5…

InternLM2-lesson5

目录 大模型部署挑战常用大模型部署方式模型剪枝(Pruning)知识蒸馏量化 LMDeploy核心功能性能表现支持部署的模型 作业配置 LMDeploy 运行环境以命令行方式与 InternLM2-Chat-1.8B 模型对话 大模型部署 大模型部署就是将大模型在特定的环境种运行&#xff01;可以部署到服务器…

The Clock and the Pizza [NeurIPS 2023 oral]

本篇文章发表于NeurIPS 2023 (oral)&#xff0c;作者来自于MIT。 文章链接&#xff1a;https://arxiv.org/abs/2306.17844 一、概述 目前&#xff0c;多模态大语言模型的出现为人工智能带来新一轮发展&#xff0c;相关理论也逐渐从纸面走向现实&#xff0c;影响着人们日常生活…

VPP 源码学习总结

当我们在VPP/plugins目录下注册了自己的node后&#xff0c; 肯定有一个node.func(), 那这个函数是如何执行到的呢&#xff1a; 1. 首先我们要看一下这个插件注册的时候做了什么&#xff0c; 假设node 如下&#xff1a; 编译成功后&#xff0c; 我们可以从函数vlib_plugin_earl…

ubuntu20.04开机运行java的sh脚本

用到了 rc.local 1、修改 /usr/lib/systemd/system/rc-local.service 在最下面添加 [Install] WantedBymulti-user.target 2、 系统没有 rc.local&#xff0c;需要手动创建 cd /etc vi rc.local在里面写入 /opt/start.sh chmod x /etc/rc.local # 添加可执行权限 chmod x…

三分钟设计自己的工厂!基于昇腾AI处理器昇思MindSpore打造的智能化工大模型为化工研发效率带来10+倍提升

前言&#xff1a;华为与大连化物所深度合作&#xff0c;联合推出智能化工大模型&#xff0c;AI赋能化工领域&#xff0c;拥抱科学创新&#xff0c;提供了数据驱动化工研发的新范式。 2024年3月22日&#xff0c;在北京国家会议中心召开的昇思人工智能框架峰会上发布了由华为AI4…